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(54) Pattern matching method and apparatus and telephone system 



(57) A method for matching an input pattern with a 
number of stored reference patterns using a dynamic 
programming matching technique is described. The ref- 
erence patterns of a reference signal which are at the 
end of a dynamic programming path for a current input 
pattern are listed in an active list 201, The dynamic pro- 
gramming paths are propagated by processing the ref- 
erence patterns on the active list, and a new active list 



205 is generated for the succeeding input pattern. The 
amount of processing required for each pattern on the 
active list is reduced by using a pointer which identifies 
the reference pattern which is the earliest in the se- 
quence of patterns of the current reference signal listed 
on the new active list during the processing of a preced- 
ing dynamic programming path. In a second aspect, a 
speech recognition interface is used as a control system 
for a telephony system. 
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Description 

The present invention relates to a method of and apparatus for pattern matching. The invention has particular, 
although not exclusive relevance to a method of implementing a dynamic programming matching technique. In an 
s exemplary embodiment, the dynamic programming matching technique is employed in a speech recognition system. 
In an aspect of the invention, functions of a telephony system are controlled using a speech recognition system.. 

Speech recognition is a process by which an unknown speech utterance is identified. There are several different, 
types of speech recognition systems currently available which can be categorised in several ways. For example, some 
systems are speaker dependent, whereas others are speaker independent. Some systems operate for a large vocab- 
10 uiary of words (> 10,000 words) while others only operate with a limited sized vocabulary (<1000 words). Some systems 
can only recognise isolated words whereas others can recognise phrases comprising a series of connected words. 

In a limited vocabulary system, speech recognition is performed by comparing features of an unknown utterance 
with 1 eat u res of known words which are stored in a database. The features of the known words are determined during 
a training session in which one or more samples of the known words are used to generate reference patterns therefor. 
*s The reference patterns may be acoustic templates of the modelled speech or statistical models, such as Hidden Markov 
Models. 

To recognise the unknown utterance, the speech recognition apparatus extracts a pattern (or features) from the 
utterance and compares it against each reference pattern stored in the database. A scoring technique is used to provide 
a measure of how well each reference pattern, or each combination of reference patterns, matches the pattern extracted 

20 from the input utterance. The unknown utterance is then recognised as the word(s) associated with the reference 
pattern (s) which most closely match the unknown utterance. 

Typically, the scoring is accomplished using a dynamic programming technique which provides an optimal time 
alignment between each of the reference patterns and the pattern extracted from the unknown utterance, by locally 
shrinking or expanding the time axis of one pattern until there is an optimal match between the pairs of patterns. The 

2S reference pattern or sequence of reference patterns having the best score identifies the word or words most likely to 
correspond to the input utterance. 

The dynamic programming matching technique is relatively computationally and memory expensive as it involves 
the determination of many possible matchings between the incoming utterance and each reference model. 

US 4592086 (Nippon Electric Co. Limited) discloses a connected digit speech recognition system which uses a 

30 dynamic programming matching technique US 4592086 discloses that the amount of memory required for the matching 
process can be reduced if the patterns of a reference model, which are at an end of a dynamic programming path, are 
processed in reverse sequential order; 

An aspect of the present invention provides a pattern matching method and apparatus which uses a dynamic 
programming matching technique, wherein the active patterns of models are processed in reverse sequential order, 

35 and wherein a last active pointer is used to control the required processing of the patterns. 

An embodiment of the present invention provides a method of performing a dynamic programming pattern matching 
process between a sequence of input patterns representative of an input signal, and a number of stored sequences 
of reference patterns, each sequence being representative of a reference signal, wherein the method processes each 
input pattern in turn with respect to at least some of the reference signals in turn, by: (1) defining as active patterns 
the reference patterns of a current reference signal which are at the end of a dynamic programming path for a current 
input pattern being processed, and listing the active patterns for the current input pattern in a current active list; (2) for 
each active pattern, storing in a store associated with that active pattern, a cumulative value representative of the score 
for the dynamic programming path which ends at that active pattern; and (3) updating the cumulative values and 
propagating the dynamic programming paths based on constraints which are placed on the dynamic programming 

45 path propagation by processing each active pattern of the current reference signal in reverse sequential order, by: (A) 
updating the cumulative value stored in the store associated with a current active pattern being processed, using the 
current input pattern; and then (B) propagating the dynamic programming path associated with the current active pat- 
tern, and listing, if it is not already listed, each reference pattern of the current reference signal, which may be at the 
end of that dynamic programming path for the succeeding input pattern, in a new active list; wherein the propagation 

50 of each dynamic programming path for a current reference signal is controlled using a pointer associated with the 
current reference signal, which identifies the reference pattern which is the earliest in the sequence of patterns of the 
current reference signal listed in the new active list, after the processing of the preceding active pattern, such that the 
propagation of each dynamic programming path is achieved without the need to search the new active list to identify 
which reference patterns, of the current reference signal, have been listed in the new active list as a result of processing 

55 preceding active patterns. The processing of the current input pattern may be processed before the next input pattern 
is ready to be processed. Each reference signal may have associated therewith a current active list and a new active list. 
In a preferred embodiment the pattern matching method is used in a speech recognition system. 
Another embodiment provides a method of and apparatus for adapting existing reference models for use by a new 
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user, which uses a statistical substitution technique. 

Another embodiment provides a method for adapting existing reference models which are used in a pattern match- 
ing system, wherein each reference model comprises a sequence of reference patterns, the method comprising the 
steps of: (a) inputting a number of input signals for which the content is known; (b) processing each input signal to 
generate a sequence of representative input patterns; (c) for each input signal, aligning the representative sequence 
of input patterns with the sequence or sequences of reference patterns of the existing reference model or models of 
the signals known to be in that input signal; (d) for each reference pattern which is aligned with a number of input 
patterns of one or more input signals: (i) combining the input patterns of the aligned input signals; and (it) replacing 
that reference pattern of the reference model with the combined input pattern determined in step (i). 

One example of an application for a speech recognition system is in a telephony system. In a modern communi- 
cation system, users are provided with a large number of telephony services. For example, the user has the ability to 
hold calls currently in progress, to transfer calls to other users and to set up conference calls with a number of other 
users. Additionally, most systems allow the storage of messages for each user, when they are not available to take a 
call. In order to accommodate these telephony services, telephone manufacturers have been increasing the size and 
complexity of the telephones by providing additional function keys on the telephone keypad. In order to access a 
telephony service, the user must press a number of keys on the telephone either in sequence or simultaneously. The 
problem with these telephones is that often a user will only familiarise himself with the combination of keys associated 
with the telephony services which he uses most often, and not the combination of keys required to activate the other 
services. Therefore, in practice, the user does not utilise the full capabilities of the telephony system available to him. 

A system has recently been proposed by Wildfire Communications Inc. which solves many of these problems with 
existing telephony systems. In particular, the system has a speech recognition user interface which allows a user to 
access telephony functions by voice command. However, the system has a problem in that to access a single command, 
the user sometimes has to input several preset commands in addition to identifiers of other users one at a time in a 
laborious and time consuming interactive procedure. 

This aspect of the present invention aims to alleviate these problems associated with the prior art system. 
One aspect of the present invention provides a control system for controlling a telephony system comprising: a 
speech recognition user interface for allowing a user to input speech commands for controlling the telephony system; 
control means responsive to the speech recognition user interface for controlling the telephony system in accordance 
with an input speech command; wherein the speech recognition user interface is adapted to be able to recognize 
continuously spoken commands comprising telephone commands and an identifier of another user by comparing the 
spoken command with a stored language model. Preferably the stored language model is adaptable by the user. 

A further aspect of the present invention provides a telephony system comprising: a speech recognition user in- 
terface for allowing a user to input speech commands for controlling telephony services provided by the system; and 
an execution means, responsive to the speech recognition interface, for executing an operation corresponding to the 
speech command; wherein each user of the system is identified by a telephone number and an associated identifier, 
and wherein the execution means is adapted to predict what telephony service is wanted if the user inputs only the 
identifier of another user. 

Another aspect of the present invention provides a mailbox facility for use with a telephony system, comprising a 
speech recognition user interface for allowing a user to input speech commands for controlling the mailbox facility; 
control means for controlling the mailbox facility in accordance with an input speech command; and storage means 
for storing messages left by callers when the users are unable to take the calls; wherein each message stored in the 
mailbox is associated with the telephone number of the caller who left the message, whereby users can request via 
the speech recognition user interface, the mailbox facility to read the messages from particular callers. 

A further aspect of the present invention provides a method performing the functions according to the above aspects 
45 of the invention relating to a telephony system. 

Various embodiments of the invention will now be described, by way of example only, with reference to the ac- 
companying drawings in which: 

Figure 1 is a schematic view of a computer which may be programmed to operate an embodiment of the present 
50 invention; 

Figure 2 is a schematic overview of a speech recognition system; 

Figure 3 is a block diagram of the preprocessor incorporated as part of the system shown in Figure 2 which illus- 
trates the processing steps that are performed on the input speech signal; 

Figure 4 is a diagrammatical representation of the division of the input speech signal S(t) into a series of time frames; 
Figure 5 is a diagrammatical representation of a typical speech signal for a single time frame; 
Figure 6 is a diagrammatical representation of the magnitude response of the discrete Fourier transform of the 
speech signal shown in Figure 5; 

Figure 7 is a diagrammatical representation of the averaged magnitude response output of a mel scale filter bank; 
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Figure 8 is a diagrammatical representation of the log magnitude spectrum of the output from the mel scale filter 
bank; 

Figure 9 is a diagrammatical representation of the cepstrum of the logged magnitude spectrum shown in Figure 8; 
Figure 10 is a schematic diagram of the reference model builder used during a training process; 
s Figure 11 is a flow chart which illustrates the steps taken during the training process for generating word models 

for use in the speech recognition system; 

Figure 12 is a schematic diagram which illustrates the manner in which the training phrases and words are stored 
during the training process; 

Figure 1 3 is a schematic representation of a number of input phrases and words, and their corresponding sequenc- 
10 es of parameter frames; 

Figure 14 is a flow chart which illustrates the steps taken in determining the word models from the input utterances, 
input during the training session; 

Figure 15 is a schematic representation of training words and their corresponding sequences of parameter frames 
which have had their ends discarded; 
1$ Figure 16 is a schematic representation of the alignment between parameter frames of the word shown in Figure 

15 and parameter frames corresponding to the input phrases in which that word appears; 

Figure 17a is a schematic representation of a language model generated during the training process for a number 
of example input phrases; 

Figure 17b is a flow chart which illustrates the manner in which the system adds a new phrase to the language 
20 model; 

Figure 18 is a schematic representation of the processing performed when an input word is aligned with a word 
model using a dynamic processing technique; 

Figure 1 9 is a schematic representation of an allowed state transition sequence from one input frame to the next; 
Figure 20 is an alternate representation of the allowed state transition sequence shown in Figure 19; 
25 Figure 21 is a flow chart which illustrates the implementation of the dynamic programming alignment technique 

used in the first embodiment; 

Figure 22 is a schematic representation of a word model and a current active list and new active list associated 
therewith; 

Figure 23 is a schematic diagram which illustrates a number of example dynamic programming paths propagating 
30 within a reference model; 

Figure 24 is a flow chart which illustrates the steps involved in step S47 shown in Figure 21 ; 

Figure 25 is a schematic diagram which illustrates the manner in which two of the dynamic programming paths 

shown in Figure 23 can propagate from the current input frame to the next; 

Figure 26a is a schematic diagram illustrating the contents of the new active list shown in Figure 22 after the first 
35 state in the current active list for the word model shown in Figure 22 has been processed; 

Figure 26b is a schematic diagram illustrating the contents of the new active list shown in Figure 22 after the second 

state in the current active list for the word model shown in Figure 22 has been processed; 

Figure 27a is a flow chart which illustrates part of the processing performed in step S77 shown in Figure 24; 

Figure 27b is a flow chart which illustrates the remaining steps involved in step S77 of Figure 24; 
40 Figure 28 is a flow chart which illustrates the processing performed in step S51 shown in Figure 21 ; 

Figure 29 is a schematic representation of the processing performed to an exemplary node N during the processing 

illustrated in Figure 28; 

Figure 30 is a flow chart which illustrates the steps involved in step S57 shown in Figure 21 ; 
Figure 31 is a schematic diagram illustrating the entry states of the word model shown in Figure 22; 
45 Figure 32 is a flow chart which illustrates the steps performed in step S65 shown in Figure 21 ; 

Figure 33 is a schematic representation of the sequence of parameter frames for an input phrase together with 
the sequences of parameter frames for the words contained within the input phrase when spoken in isolation; 
Figure 34 is a flow chart which illustrates the steps involved in adapting the word models lo a different user using 
a first substitution technique; 

50 Figure 35 is a flow chart which illustrates the steps involved in adapting the word models to a different user using 

a second substitution technique; 

Figure 36 is a schematic diagram of a telephony system according to an embodiment of the present invention; 
Figure 37 is a schematic representation of a telephone used in the telephony system shown in Figure 36; 
Figure 38 is a schematic diagram illustrating some of the internal components of a local exchange of the telephony 
55 system of Figure 36; 

Figure 39 is a block schematic diagram illustrating the main components of a control unit of the local exchange of 
Figure 37; 

Figure 40 is a schematic diagram illustrating a new message list, an old message list, a current message list and 
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a waste basket used by a mail box facility of the telephony system in accordance with an embodiment of the present 
invention; and 

Figure 41 is a flow chart illustrating the processing steps involved in replaying messages from the mail box facility 
of Figure 40. 

5 

Embodiments of the present invention can be implemented in computer hardware, but the embodiment to be 
described is implemented in software which is run in conjunction with processing hardware such as a personal com- 
puter, workstation, photocopier, facsimile machine or the like. 

Figure 1 shows a personal computer (PC).1 which may be programmed to operate an embodiment of the present 
io invention. A keyboard 3, a pointing device 5, a microphone 7 and a telephone line 9 are connected to the PC 1 via an 
interface 11. The keyboard 3 and pointing device 5 enable the system to be controlled by a user. The microphone 7 
converts the acoustic speech signal of the user into an equivalent electrical signal and supplies this to the PC 1 for 
processing. In this embodiment, the beginning and end points of the input speech to be processed, are identified by 
the user holding the spacebar on the keyboard 3 down for the duration of the input utterance. In this manner, the system 
only processes the input utterance to be identified. An internal modem and speech receiving circuit (not shown) may 
be connected to the telephone line 9 so that the PC 1 can communicate with, for example, a remote computer or with 
a remote user. 

The programme instructions which make the PC 1 operate in accordance with the present invention may be sup- 
plied for use with an existing PC 1 on a storage device such as a magnetic disc 13, or by the internal modem commu- 
te nicating with a remote computer via the telephone line 9. 

The operation of the limited vocabulary continuous speech recognition system of this embodiment will now be 
described with reference to Figure 2. Electrical signals representative of the input speech from, for example, the mi- 
crophone 7 are applied to a preprocessor 15 which converts the input speech signal into a sequence of parameter 
frames, each representing a corresponding time frame of the input speech signal. The sequence of parameter frames 
25 are supplied to a recognition block where the speech is recognised by comparing the input sequence of parameter 
frames with reference models or word models 1 9, each model comprising a sequence of parameter frames expressed 
in the same kind of parameters as those of the input speech to be recognised. 

A language model 21 and a noise model 23 are also provided as inputs to the recognition block 17 to aid in the 
recognition process. The noise model is representative of silence or background noise and, in this embodiment, com- 
prises a single parameter frame of the same type as those of the input speech signal to be recognised. The language 
model 21 is used to constrain the allowed sequence of words output from the recognition block 17 so as to conform 
with sequences of words known to the system. The word sequence output from the recognition block 17 may then be 
transcribed for use in, for example, a word processing package or can be used as operator commands to initiate, stop 
or modify the action of the PC 1 . 
55 A more detailed explanation will now be given of the apparatus described above. 

Preprocessor 

The preprocessor will now be described with the aid of Figures 3 to 10. 
40 The functions of the preprocessor 15 are to extract the information required from the speech and to reduce the 

amount of data that has to be processed. There are many known methods of preprocessing speech in the field of 
speech analysis and the following method is given by way of example only and should not be construed as limiting in 
any way. In this embodiment the preprocessor 15 is designed to extract formant" related information. Formants are 
defined as being the resonant frequencies of the vocal tract of the user, which change as the shape of the vocal tract 
changes. 

Figure 3 shows a block diagram of the preprocessing that is performed on the input speech signal. Input speech 
S(t) from the microphone 7 or the telephone line 9 is supplied to filter block 61 , which removes frequencies within the 
input speech signal that contain little meaningful information/in speech signals, most of the meaningful information is 
contained below 4KHz. Therefore, filter block 61 removes all frequencies above 4KHz. The filtered speech signal is 
then converted into digital samples by the analogue-to-digital converter (ADC) 63. To adhere to the Nyquist sampling 
criterion, ADC 63 samples the filtered signal at a rate of 8000 times per second. In this embodiment, the whole input 
speech utterance is converted into digital samples and stored in a buffer (not shown), prior to the subsequent steps in 
the processing of the speech signals. 

After the input speech has been sampled it is divided into overlapping equal length frames in block 65. The reason 
55 for this division of the input speech into frames will now be described in more detail. As mentioned above, during 
continuous speech the formant related information changes continuously, the rate of change being directly related to 
the rate of movement of the speech articulators which is limited by physiological constraints. Therefore, in order to 
track the changing formant frequencies, the speech signal must be analysed over short time periods or frames, this 
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method being known in the art of speech analysis as a "short time" analysis of speech. There are two considerations 
that have to be addressed when performing a short time analysis; (i) what rate should the time frames be extracted 
from the speech signal, and (ii) how large a time frame should be used. 

The first consideration depends on the rate of movement of the speech articulators i.e. the frames should be 

5 sufficiently close to ensure that important events are not missed and to ensure that there is reasonable continuity. In 
this embodiment, a frame is extracted once every 10 milliseconds. The second consideration is determined by a com- 
promise between the time frame being short enough so that the speech signal's properties during the frame are con- 
stant, and the frame being long enough to give sufficient frequency detail so that the formants can be distinguished. 
In the present embodiment, the frames are 20 milliseconds in length which, with the above sampling rate, corresponds 

io to 160 samples per Irame. 

If these frames are generated by extracting the frames directly from the speech samples, considerable frequency 
distortion results. Therefore, to reduce such distortions, a smoothed window function should be used. There are many 
such windows available including Hamming, Hanning, Blackman, Bartlett and Kaiser all of which will be known to those 
skilled in the art of speech analysis. In the present embodiment, a Hamming window is used, this being represented 

*s by the following equation: 

W(n) = 0.54 -0.46 cos [2rcn/( rV £ -1 )] (1) 

20 where N s is the number of samples in the window, i.e. 160 samples. 

Figure 4 shows in more detail the short time analysis operation that is carried out in the present embodiment. The 
speech signal in frame 1 , i.e. between time instant "a" and time instant "b", is multiplied by the window function given 
in equation (1 ). Further, due to the choice of the frame rate and the frame length, the next frame : frame 2, starts midway 
between frame 1 at time instant "c" etc. 

25 Once a frame of input speech signal has been extracted, the magnitude of the discrete Fourier transform (DFT) 

of the frame is calculated in block 67, i.e. IS k (f)l where f is the discrete frequency variable. Only the magnitude infor- 
mation is required, since many aspects of this preprocessor are designed to simulate the operation of the human 
auditory system, which is relatively insensitive to the phase of the input speech signal. Figure 5 shows a typical speech 
signal for a single frame S k (r) comprising 160 samples, i.e. r=0,1 ,...159. To enable an efficient Fast Fourier Transform 

30 (FFT) algorithm to be used in the calculation of the DFT, the number of samples within the frame S k (r) needs to be 
increased to a power of 2. One method of achieving this is by adding 96 zero's at the end of the 160 samples to give 
256 samples. This technique is known as "padding with zeros' and is well known in the art of speech analysis, and 
will not be described further. 

In computing the DFT of S k (r), only the first 128 samples of the spectrum need to be computed, since speech is 
35 a real signal and so the second 128 samples will be a mirror image of the first 128 samples. Figure 6 shows the first 
128 samples of the magnitude of the DFT IS k (f)l of the speech signal in frame S k (r) shown in Figure 5, the last sample 
of which occurs at a frequency of half the sampling frequency, i.e. 4KHz. 

As mentioned earlier, the purpose of preprocessor 15 is to reduce the data rate and to emphasise particular com- 
ponents of the input speech signal. The data rate has been reduced slightly by the DFT, since there are now only 1 28 
40 samples per frame. One method of reducing the data rate further is to split the spectrum into a number of equal fre- 
quency bands and to average the samples within each band, i.e. pass the samples shown in Figure 6 through a filter 
bank. 

Studies on the human auditory system have shown that the ear frequency resolution decreases with increasing 
frequency. Therefore, a logarithmically spaced filter bank, i.e. one in which there are more frequency bands in the low 
frequency region compared to the high frequency region, is preferable to a linearly spaced filter bank since a logarith- 
mically spaced filter bank retains more perceptually meaningful information. 

In the present embodiment, a mel spaced filter bank 69 having nineteen bands is used. The mel scale is well 
known in the art of speech analysis, and is a logarithmic scale that attempts to map the perceived frequency of a tone 
onto a linear scale. Figure 7 shows the output IS k (f')l of the mel spaced filter bank 69, when the samples shown in 
50 Figure 6 are passed through the bank 69. The resulting envelope 100 of the magnitude spectrum is considerably 
smoother due to the averaging effect of the filter bank 69, although less smooth at the lower frequencies due to the 
logarithmic spacing of the filter bank. 

The formant related information is then extracted from the speech using blocks 71, 73 and 75 of Figure 3, by a 
process which will now be explained. 

It is possible to model the speech signal S(t) of a user in terms of an excitation signal E(t) and a filter V(t), where 
the excitation signal E(t) represents the airflow entering the vocal tract, and the filter V(t) represents the filtration effect 
of the vocal tract. Consequently, the magnitude of the frequency spectrum IS(f)l of the speech signal is given by the 
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multiplication of the magnitude of the frequency spectrum IE(f)l of the excitation signal with the magnitude of the spec- 
trum IV(f)l of the vocal tract filter, i.e. 



5 \S(f)l =\E(f)\AV{f)\ (2) 

One method, known as the cepstral method, of extracting the vocal tract information from the input speech will 
now be described. This method involves separating the vocal tract filter magnitude response IV(f)l from the excitation 
magnitude response IE(f )l by taking the logarithm of the speech magnitude response !S(f)l, which results in the exci- 
J o tation and vocal tract filter characteristics becoming additive, i.e. 
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loglS(OI = \oq\E(f)\ + logl V(f)\ (3 ) 

Figure 8 shows the envelope of the logged output from the mel filter bank 69, i.e. log !i* (f )l, which shows graphically 
the additive nature of two components 101 and 103. Component 101 is representative of the vocal tract characteristics, 
i.e. log IV(f)l, and component 103 is representative of the excitation characteristics, i.e. log IE(f)l. The peaks in com- 
ponent 101 occur at the formant frequencies of the vocal tract and the equally spaced peaks in component 103 occur 
at the harmonic frequencies of the pitch of the speaker. 

The vocal tract characteristics 101 can be extracted from the excitation characteristics 103, by performing a Dis- 
crete Cosine Transform (DCT) on the samples output from block 71 , and then filtering the result. 

Figure 9 shows the output of the DCT block 73 : which is known as the cepstrum C k (m). The independent variable 
(x-axis of Figure 9) of the cepstrum has dimensions of time and is given the name "quefrency". The strongly periodic 
component 103 shown in Figure 8 becomes a peak 105 in the cepstrum at a location equivalent to the pitch period T 
of the speaker. The slowly varying component 101 shown in Figure 8, is transformed onto a number of small peaks 
107 near the origin of the cepstrum, the position and amplitude of which are dependent on the formants. 

As the vocal tract characteristics and the excitation characteristics of speech appear in separate parts of the que- 
frency scale, they can be separated from one another by a filtering process, or, in cepstral terminology by a so called 
-littering 0 process. The cepstrum C^m) shown in Figure 9 is made up of a set of discrete cepstral coefficients (C 0 , 
c i. C 18 ), and therefore the littering could be achieved by means of a simple rectangular window However, in order 
to de-emphasise parts of the spectrum that are considered to be less reliable, a more gradual windowing function is 
preferred. 

In the present embodiment, the following window function is used in littering block 75: 



where N c is the desired number of cepstral coefficients output per frame from the littering block 75, which in the present 
40 embodiment is twelve. 

In addition to the twelve cepstral coefficients mentioned above, the power of the speech signal within each frame, 
i.e. the frame power" is also calculated. This is an important feature since it can be used, among other things, to 
indicate whether or not the input speech signal during the frame corresponds to a voiced speech signal. The frame 
power is calculated in frame power block 81 shown in Figure 3 using a conventional method well known in the art of 
speech analysis. To achieve independence of variable recording conditions, variable loudness etc, the power deter- 
mined in block 81 is normalised in power normalising block 83 to give a power coefficient P k which is combined with 
the cepstral coefficients output from the liftering block 75. The power is normalised in block 83 by determining the 
maximum power (dB) across the utterance stored in the buffer (not shown), subtracting this from the power of each 
frame and multiplying the result by a normalisation constant. 

Whereas in the present embodiment, the power of the input speech signal during each frame is determined, other 
values indicative of the input speech signal during each frame could be used. For example, a measure of the average 
magnitude of the input speech signal during a frame could be determined and normalised. 

In summary, the preprocessor 15 outputs, for each time frame, a set of coefficients - twelve cepstral coefficients 
and one power coefficient. For convenience, the coefficients that represent frame k will be referred to as parameter 
frame f k , and the coefficients that represent the subsequent frame will be referred to as parameter frame f k+1 etc. 
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Buffer 

The parameter frames f k output from preprocessor 1 5 are applied to the buffer 1 6 shown in Figure 2. In the present 
embodiment, the buffer 16 is large enough to store all the parameter frames generated for the speech stored in the 
s buffer (not shown) which stores the digital samples output from ADC 63 for the input speech. After the entire input 
utterance has been processed by the preprocessor 15, the parameter frames stored in buffer 16 are fed to the recog- 
nition block 17 in the order that they are received, where the input utterance is recognised. 

Reference Models 

w 

As mentioned above, in order to determine which words are represented by the output signals Irom the preproc- 
essor 15, these signals are compared with stored reference models which model the words already known to the 
system and the acoustic environment surrounding the system. Each model associated with a particular word comprises 
a sequence of parameter frames of the same type of parameter frames output from the preprocessor 1 5 described 
is above. However, to differentiate between the frames in the word models and the frames in the input utterance to be 
recognised, the frames in the word models will be referred to as states. 

One feature of the speech recognition system according to this embodiment is that it can be supplied to the end 
user with no word models, environment (or noise) model or language model pre-stored therein. This allows the user 
the freedom to train the system to recognise the phrases he wants, without the system being overburdened with pre- 
20 stored words which may not be useful for the user's purpose. Further, as will be seen from the following description, 
the particular training method described is particularly adapted to this situation because it allows for new phrases to 
be learnt by the system without the need for a time consuming training session. In addition, since the reference models 
correspond to whole words and not phonemes, the system will work for any language or even any mixture of languages. 
The training process will now be described in more detail with reference to Figures 10 to 17. 

25 

Training 

Figure 10 is a schematic diagram which illustrates the build/update module 91 which is used in the training process. 
In particular, the build/update module 91 receives sequences of parameter frames f k representative of a word or words 

30 to be learnt by the system, and user information, represented by arrow 92, indicative of the text corresponding to the 
input spoken word or words. If sufficient information has been input into the build/update module 91 then it generates 
word models corresponding to the input words and updates the language model 21 . In this embodiment, both the word 
models and the language model are stored in a high volume data storage unit, such as a hard disc 93. 

The manner in which the noise model 23 is determined in this embodiment will now be described. Firstly, the user 

35 indicates that he wishes to build a new or change the existing noise model 23. In response, the system prompts the 
user to input sound representative of silence. This is achieved by the user holding down the spacebar on the keyboard 
3 while remaining silent. At the end of the period of silence : the user must then utter a word so that the system can 
normalise the power coefficient of the generated parameter frames representative of the silence. If the user does not 
utter a word at the end of the period of silence then the power coefficient for the noise model 23 will be unrealistically 

40 high, and mis recognition errors may result. Finally, in order to determine the noise model 23, the system averages the 
parameter frames generated for the period of silence to produce a single parameter frame which is used as the noise 
model 23. 

The speech recognition system of this embodiment is designed to recognise continuously spoken words, i.e. words 
embedded within phrases. In order to achieve good recognition results, the reference models (or continuous word 

45 models) should be derived from example phrases which contain the words of interest. Unfortunately, it is not an easy 
task to identify the beginning and end points of a word within a continuously spoken phrase. An overview of the way 
in which the present embodiment generates a continuous word model will now be given. Firstly, the system determines 
a model for the word from an isolated utterance of that word. This model will be referred to as the "isolated word model" 
although, as those skilled in the art of speech recognition will realise from the following description, these isolated word 

50 models may not correspond to conventional isolated word models well known in the art. The system then uses the 
isolated word models to generate the continuous word models by comparing the isolated word models with example 
phrases containing the corresponding words. 

To generate the isolated word model, the word must be input into the system via the microphone 7 or the telephone 
line in isolation. As described above, the space bar is used to identify each incoming utterance. Therefore, the sequence 

55 of parameter frames representative of the isolated utterance of the word will comprise parameter frames at the begin- 
ning and end thereof which correspond to silence. The system then compares the utterance of the isolated word with 
example phrases which contain that word. This comparison identifies approximate beginning and end points of the 
word within the isolated utterance. These beginning and end points are then averaged and the isolated word model 
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for the word is determined by extracting the sequence of parameter frames which lies between the averaged beginning 
and end points. By determining the isolated word model in this way, not only should the silence at the beginning and 
end of the word be removed, but parts of the word which are not pronounced during continuous speech will also be 
removed. Therefore, the isolated word model may not correspond to a conventional isolated word model, which is 
s determined by removing the silence from the beginning and ends of the input utterance, and will be more representative 
of the word when spoken in continuous speech. 

Once the isolated word model has been determined, it is aligned with the example phrases which contain that 
word in order to identify the location of the word within the phrase. Finally, the reference or continuous word model is 
determined by extracting and combining the speech from the locations identified in the phrases. The way in which the 
to system generates the word models will now be described in more detail. 

When the user wishes to teach the system one or more new phrases, the user initiates the subroutine shown in 
Figure 11 . In step S1 the user enters the text of the new word or phrase into the system via the keyboard 3. The system 
then checks whether that word or phrase is already known, and if it is not then in step S3, it prompts the user to enter 
the same word or phrase via the microphone 7, and associates the utterance with the corresponding text input in step 
is S1 . Next in step S5 the PC 1 uses all the text which has been previously entered, to check whether any of the words 
within the phrase have been input (in isolation) already, and prompts the user to input, in isolation via the microphone 
7, those words that have not been entered before. 

After step S5, the user decides whether to enter another new word or phrase in step S7, and returns to step Si if 
he does. On the other hand, if the user decides not to input any more phrases, then the processing moves to step S9 
20 where reference models are generated for unknown words which are included in at least two phrases input into the 
system. For example, if no training phrases have been input, and the system has no pre-stored reference models, and 
the user decides to input the phrases "get an image" and "get the earth", and then decides in step S7 that he does not 
wish to enter any more phrases, then the system will only be able to generate a word model for the word 'get", since 
it is the only word that is in both of the input phrases. If on the other hand the user inputs the phrase "get an image" 
2S twice, then the system will be able to generate a reference model for each word in the phrase. Taking the first example 
mentioned above further, if the user decides to input the phrase "get the earth" in a second training session after 
inputting the first two phrases, then the system will not prompt the user for the words "get" or "the" in step S5 since 
these words will have been input in isolation already. Further, the system will now be able to generate a reference 
model for the word "the" since it now appears in two phrases which have been input into the system. In this way, the 
30 training is incremental and can be trained at the convenience of the user. 

Referring to Figure 12, each phrase input in the above manner is given a phrase number P and is stored in a 
phrase array 115 on the hard disc 93. Similarly, each isolated word that is input is given a word number W and is stored 
in a word array 1 1 7 on the hard disc 93. As shown in Figure 1 2, each phrase P in the phrase array 1 1 5 has an associated 
sequence of parameter frames 123, the sequence of words 125 that form the phrase and a status flag 127. Each word 
in the sequence of words 125 has an associated text 129 of the word, the phrase number R the word number 131 (L 
e. the position of the word within the phrase), the time boundaries 1 33 of the word within the phrase and a word index 
135 which points to the corresponding isolated word W in the word array 117. Each isolated word W in the word array 
1 17 has an associated sequence of parameter frames 1 37, a phrase index 1 39 which points back to those phrases in 
which that word can be found and a status flag 1 41 . 

Initially, when the isolated words and phrases are being entered into the system, the status flags 127 and 141 
associated with each word or phrase are labelled FLEXI to indicate that they have not been processed, and the time 
boundaries 133, associated with each word within the sequence of words in the phrase, are set to UNKNOWN. 

The generation of the word models for the unknown words performed in step S9 of Figure 11 will now be briefly 
described with reference to Figures 12 to 16, using as an example the training phrases "get an image" which has been 
input twice, and "get the earth" which has been input once. Therefore, there will be three elements PI, P2 and P3 in 
the phrase array 1 1 5, one lor each utterance of the phrase "get an image" and one for the utterance of the phrase "get 
the earth". Additionally, there will be five elements Wl, W2, W3, W4 and W5 in the words array 117, one for each of 
the different words that make up the two phrases. As described above, a sequence of parameter frames corresponding 
to each phrase and corresponding to each of the different words will be stored in the corresponding elements in the 
so phrase array 115 and word array 117. 

Figure 13 shows speech signals 151 and 153 which represent the two utterances of the phrase "get an image" 
and speech signal 1 55 which represents the utterance of the phrase "get the earth". Figure 1 3 also shows the speech 
signals 157, 159 and 161 which represent the isolated utterances of the words "get", "an" and "image" respectively 
Figure 13 also shows the two sequences of parameter frames 152 and 154 which correspond to the two utterances of 
the phrase "get an image", the sequence of parameter frames 156 corresponding to the utterance of the phrase "get 
the earth" and the sequences of parameter frames 158, 160 and 162 corresponding to the utterances of the isolated 
words "get", "an" and "image" respectively. Representations of the words "the" and "earth" are not shown in Figure 13, 
since word models for these words cannot be generated as they do not appear in two or more phrases. 
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Figure 14 shows in more detail the steps required to generate a word model for each of the unknown words. In 
particular, in step S21 the sequences of parameter frames corresponding to the input phrases that contain the unknown 
words are aligned with the sequences of parameter frames corresponding to the unknown words when spoken in 
isolation, using a flexible dynamic programming alignment process which accommodates the initial lack of knowledge 
5 of the start and end points of the unknown words, in particular, a dynamic programming alignment process is used that 
does not constrain where the optimum alignment path of each word must begin or end. This flexible dynamic program- 
ming alignment process will be described in more detail later after dynamic programming alignment has been discussed. 

The result of the flexible dynamic programming alignment is the identification of an approximate start and end 
point of each unknown word within the sequence of parameter frames for that unknown word. For example, when the 
10 sequence of parameter frames 152 corresponding to the first utterance of the phrase "get an image" is aligned with 
the sequence of parameter frames 1 58 corresponding to the utterance of the unknown word "get", a start and end 
point of that word within the sequence of parameter frames 1 58 are identified from the alignment results. As mentioned 
above, the parameter frames before the start point and after the end point correspond to background noise, or parts 
of the word which are not pronounced in the example phrases, and can therefore be removed. 
is The alignment performed in step S21 for the example training phrases will identify three sets of start and end points 

for the word "get" (since the word "get" appears in three phrases) and two sets of start and end points for the words 
"an" and "image" (since the words "an" and "image" appear in two phrases). In step S23 an average start and end 
point for each unknown word are determined and the frames before the average start frame and after the average end 
frame are discarded. For example, if after step S21 for the word "get" the start points identified using the three phrases 
20 151 , 153 and 155 are frame f 8 W1 , frame f 9 W1 and frame f 13 w1 , then the average is frame f 10 W1 ([8+9+1 3]/3) and all 
frames in the sequence of parameter frames 1 58 before frame f l0 W1 are discarded. A similar procedure is used for the 
end points, except that it is the frames beyond the end frame which are discarded. The resulting sequence of parameter 
frames for each word is the isolated word model mentioned above for that word. 

Figure 15 shows the speech signals 157', 159 and 161 and the corresponding sequences of parameter frames of 
2B the isolated word models 158', 160 and 162 for the words "get", "an" and "image" respectively. At this stage in the 
processing, the status flag 141 , shown in Figure 12, for each word processed is changed from FLEXI to CHOPPED to 
signify that the unknown words have had the frames from the beginning and ends removed. 

Next in step S25 shown in Figure 14, the sequences of parameter frames corresponding to the input phrases are 
aligned with the sequences of parameter frames of the isolated word models for the words in those phrases. For 
30 example, the sequences of parameter frames 152, 154 and 156 corresponding to the utterances of phrases in which 
the word "get" appears are aligned with the sequence of parameter frames of the isolated word model 1 58* for the word 
"get". Figure 16 shows the resulting alignment achieved between the sequences 152,154 and 156 and the sequence 
158\ where the dashed lines represent the alignment between the frames. As shown, it is established that frames f 2 P1 
and f 3 p1 are aligned with frame f 10 w1 > and frames f 4 P1 and f 5 P1 are aligned with frame etc. 
35 Next in step S27 shown in Figure 14, a reference model for the unknown word is generated by replacing the 

individual frames of the isolated word model with the average of the aligned frames from the sequences of parameter 
frames corresponding to the phrases. For example, for the sequence of parameter frames of the isolated word model 
158' shown in Figure 16, frame f 10 W1 is replaced by the average of frames f 2 p \ f 3 p1 , f-, P2 and f 2 P3 , whilst frame l^ 1 
is replaced by the average of frames f 4 pi , f 5 P1 , f 2 P2 , t 3 P2 and f 3 P3 etc : In the event that there are no frames of a phrase 
40 aligned with one of the frames of the isolated word model, then that particular frame is replaced by a frame derived by 
interpolating between or extrapolating from neighbouring replaced frames. Therefore, for the sequence of parameter 
frames 1 58* shown in Figure 1 6, frame f 1 2 W1 is not aligned with any of the frames in the sequences of parameter frames 
152, 154 or 156, and is replaced by a frame derived by interpolating between the substituted frames for f in wi and 
f 13 W1 . Alternatively, the frames of the isolated word model which are not aligned with any frames of the phrase can be 
45 discarded. 

7he reference word models generated in step S27 are ready for use in the speech recognition part of the system, 
which will be described further below. Therefore, the status flag 1 41 of each word that has been processed is changed 
from CHOPPED to IN-USE. 

Once a reference word model has been created tor all the words in a phrase, then that phrase can be added to 
50 the language model 21 shown in Figure 2. In this embodiment, the language model 21 is similar to a Bigram model, 
and comprises a mesh of interconnected nodes, where the interconnections represent the words known to the system. 
It does not, however, contain any grammatical rules concerning, for example, correct English language usage. It only 
constrains which words can follow others based on the phrases known to it. Figure 17a illustrates the language model 
21 derived when the following phrases have been learnt by the system: 

55 

get an image - phrase 1 
get the earth - phrase 2 
get the fjord - phrase 3 
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get the map - phrase 4 

get the coin - phrase 5 

save an image - phrase 6 

load an image - phrase 7 
5 make it smaller - phrase 8 

make it larger - phrase 9 

make it brighter - phrase 10 

make it more red - phrase 1 1 

make it more yellow - phrase 1 2 
10 make it more green - phrase 13 

make it more cyan - phrase 14 

make it more blue - phrase 15 

make it more magenta - phrase 16 

quit -phrase 17 

75 

As shown in Figure 17a there is a start node N 0 , an end node N n and eight intermediate nodes N 1 to N 8 . For an 
input phrase to be recognised the system must find a path from the start node N 0 to (he end node N n . The system is, 
however, reasonably flexible in that once trained and the user inputs the phrase "make smaller' instead of "make it 
smaller 0 the system will still recognise the input phrase. The system will not, however, recognise a phrase that is input 
if that phrase is not known to the system even if the individual words in the phrase are known, i.e. for the language 
model given above, if the user says "save the image" the system will not recognise this input even though it knows the 
words "save", "the" and "image". 

The language model 21 is created by extracting the necessary word sequence constraints from the text input in 
step S3 in Figure 11 and is updated after each new phrase has been input provided there is a word model for each of 
the words in the phrase. The way in which the language model 21 is updated will now be described with reference to 
Figure 17b. 

When a new input phrase has been input and a word model for each word in the phrase has been determined, 
the system identifies in step S30, whether the first word in the phrase is already connected to the output of the start 
node N 0 . If it is, then the processing proceeds to step S32. If on the other hand, the first word is not already connected 
30 to the output of the start node N 0 , then a new output from the start node N 0 is added, in step S31 , for the first word. 

The processing then proceeds to step S32 where the system initialises a word bop counter w, which is used to 
count through all the words in the phrase. The processing then proceeds to step S33 where the system determines 
whether or not word w is the last word in the phrase. If it is not, then the processing proceeds to step S34 where the 
system determines whether or not word w is connected to the input of a node (except the end node N n ). If it is, then 
35 the processing proceeds to step S36 where the system checks to see if the next word w+1 is connected to the output 
of the node that has word w as an input. If on the other hand, at step S34, the system determines that word w is not 
connected to the input of any node, then the processing proceeds to step S35 where a new node is created and word 
w is connected to the input of that new node. The processing then proceeds to step S36 described above. 

If the system determines, in step S36, that the next word w+1 is not connected to the output of the node that has 
word w as an input, then the processing proceeds to step S37 where the next word w+1 is added as an output of that 
node. If on the other hand the system determines, in step S36, that the next word w+1 is already connected to the 
output of the node that has word w as an input, then nothing happens and the processing proceeds to step S38 where 
the word counter w is incremented. The processing then returns to step S33 and a similar procedure is carried out for 
the next word in the phrase. If the system determines at step S33 that word w is the last word in the phrase, then the 
processing proceeds to step S39 where the system determines whether or not the last word is already connected to 
the input ol the end node N n . If it is not connected to the input of the end node N n then the processing proceeds to 
step S40 where the system connects the last word in the phrase to the input of the end node N n . If the last word is 
already connected to the last node N n , or once the last word has been connected to the last node N n in step S40, then 
the processing is complete and the phrase now forms part of the language model 21. 

One feature of the training process is that the system can be taught the phrases individually or it can be taught a 
number of phrases at once. Further, if a new phrase is input and the system already has word models for some of the 
words in that phrase, then it only needs to generate word models for the unknown words before it can update the 
language model 21 . 

55 Dynamic Programming (DP) 

In the processing performed in steps S21 and S25 of Figure 14, an alignment procedure was used to align the 
parameter frames of the phrases with the parameter frames of the words. In order to align the two sequences of 
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parameter frames in an effective manner, the alignment process must be able to compensate for the different rates at 
which the word is spoken, for example when the word is spoken in isolation and when the word is embedded within 
the continuously spoken phrase. The dynamic programming (DP) alignment process mentioned above is one way 
which can match one word onto another in a way which applies the optimum non-linear time-scale distortion to achieve 

5 the best match at all points. 

An overview of the DP matching process will now be given with reference to Figures 18-20. Figure 18 shows along 
the abscissa a sequence of parameter frames representative of an input word, and along the ordinate a sequence of 
parameter frames representative of a word model. Comparing this example with the processing performed in step S25 
in Figure 14, the sequence of parameter frames representative of the input word may represent part of the sequence 

10 of parameter frames corresponding to one of the input phrases, and the sequence of parameter frames representative 
of the word model may represent the sequence of frames representing one of the chopped words. 

To find the total difference between the word model and the input word, it is necessary to find the sum of all distances 
between the individual pairs of frames along whichever path between the bottom left and top right comers in Figure 
18 that gives the smallest cumulative distance. This definition will ensure that corresponding frames of similar words 

is are correctly aligned. One way of calculating this total distance is to consider all possible paths and add the value of 
d(k,j) (the distance between frame k and frame j) for each point along each one. The distance measured between the 
two words is then taken to be the lowest value obtained for the cumulative distance. Although this method gives the 
correct answer, the number of valid paths becomes so large that the computation is impossible for any practical speech 
recognition system. 

20 Dynamic programming is a mathematical technique which finds the cumulative distance along the optimum path 

without having to calculate the distance along all possible paths. The number of paths along which the cumulative 
distance is determined can be reduced further by placing certain constraints on the DP process. For example, it can 
be assumed that the optimum path will always go forward with a non-negative slope, otherwise one of the words will 
be a time reversed version of the other. Another constraint that can be placed on the DP process is to limit the maximum 

25 amount of time compression/expansion of the input word relative to the reference word. In this embodiment, this con- 
straint is realised by limiting the number of frames that can be skipped or repeated in the matching process. For example, 
in Figure 19 the frame sequence is constrained such that if frame f k is matched to frame fj m then frame f k+1 can be 
matched with frame f- m , f^j m , fj+2 m or fj+3 m Therefore, if parameter frame f k of the input word and parameter frame fj m 
of the word model lie on the optimum path then the above constraint necessitates that the immediately preceding point 

30 on the optimum path must be either (k-1 j), (k-1 ,j-1 ), (k-1 ,j-2) or (k-1 J-3), as illustrated in Figure 20. 

Figure 18 shows the "valid paths' which are propagated up to frame f k ^ which represent possible matchings 
between the input word and the word model. When frame f k is applied to the recognition unit 17 each valid path has 
the local distance between current frame f k and the frame of the word model that is at the end of that valid path added 
to its cumulative distance. If a number of valid paths meet at the same point then the valid path with the lowest cumulative 

35 distance is continued and the others are discarded. For example, in Figure 18 path SA, B and C meet at point (k,j) and 
the path (A, B or C) with the lowest cumulative distance is continued whereas the other two are discarded. 

Therefore, if D(k, j) is the cumulative distance along a valid path from the beginning of the word to the point (k,j), i.e.: 



k *j 

2 d{x,y) (S \ 

along a 
valid path 

45 

Then, with the above constraints it follows that: 

D( k,j) = d(kj) + m\n[D(k^ J),D(k-1 ), 

so 

D(*-1,/-2).D(*-1 i /-3)] (6) 

With the above constraints, the value of D(0,0) must equal d(0,0), d(1,0), d(2,0) or d(3,0), as all possible paths 
must begin at one of these points. Therefore, starting from one of the starting points, the value of D(k,j) can be deter- 
55 mined via a recursive processing routine. When the routine reaches the end of the words to be matched, the minimum 
cumulative distance calculated by the DP process represents the score for the best way of matching the two words. If 
the input utterance to be recognised comprises a sequence of words then backpointers must be used to indicate the 
direction that has been taken, so that after the DP process identifies the end of the optimum path, it is possible to 
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recognise the input utterance by tracing back through the backpointers. 

Although the DP process described above provides a large computational saving compared with the exhaustive 
search of all possible paths, the remaining computation can be substantial, particularly if each incoming word has to 
be compared with a large number of word models for matching. Any possible saving in computation which does not 
significantly affect the accuracy of the recognition result is therefore desirable. One possible computational saving is 
to prevent paths that are scoring badly from propagating further. This is sometimes known as pruning because the 
growing paths are like branches of a tree. By pruning the paths in this way, only a narrow band of possible paths are 
considered which lie on either side of the best path. It will be appreciated that where such pruning is used it can no 
longer be guaranteed that the dynamic programming process will find the optimum path. However, with a pruning 
threshold that reduces the average amount of computation by, for example a factor of 5 to 10, the right path will almost 
always be obtained where the words are fairly similar. 

In this embodiment, the recognition block 17 shown in Figure 2 uses a dynamic programming matching process 
similar to the one described above, for matching the sequence of parameter frames for the utterance to be recognised 
with the word models 1 9 and noise model 23. 

Recognition Search 

Another feature of the speech recognition system according to this embodiment is the manner in which the dynamic 
programming process is implemented. In particular, this embodiment makes use of the fact that the minimum calculation 
performed in equation (6) above, i.e. 



min/X>f/c-1 J),D(k^ ,/-1),0flc-1 ,y-2),D(k-2,y-3)] ' (7) 

does not depend upon the current frame f K being processed. Therefore, this part of equation (6) can be calculated 
when the previous frame f ko is being processed. 

The manner in which the dynamic programming process is implemented will now be explained with reference to 
Figures 21 to 31. 

Figure 21 is a flow chart illustrating the processing performed in the recognition block 17 when an input utterance 
is to be recognised The system processes the parameter frames of the input utterance in the sequence that they are 
generated by the preprocessor 15. For this purpose a frame counter variable k is provided which is initialised to zero 
in step S41 and is subsequently incremented after each frame is processed in step S61 . Each frame being processed 
is used in step S47 to update the cumulative distances of the remaining valid paths within each word model. For this 
purpose a word counter w is provided and initialised in step S43 and incremented after step S47 in step S49. In step 
S45 the system checks to see if all the word models have been processed using the current frame, i.e. it checks to 
see whether the word counter w is less than the number of words known to the system rv 

Once each word model has been processed using the current frame f k the processing passes to step S51 where 
the nodes of the language model 21 shown in Figure 17a are processed using the current frame. The processing 
performed in step S51 takes care of the situation where the current parameter frame corresponds to silence at the 
beginning or end of the input speech or between allowed sequences of words in the input speech. This processing 
also ensures that the valid paths can only propagate through allowed sequences of words. 

After the nodes have been processed in step S51 , the cumulative distances for the valid paths which end at one 
of the beginning or "entry states" of each word model are updated in step S57. This processing is to cope with the 
situation where the next parameter frame f k+1 is matched with the beginning of a word model, when the current pa- 
rameter frame f k is matched with the end ofanother word model. To achieve this, the word counter w is reinitialised to 
zero in step S53, and the system checks, in step S55, whether all the word models have been processed. The system 
then updates, in step S57, the cumulative distances for the entry states of the current word model, and the word count 
w is incremented in step S59. The processing then returns to step S55. 

After all the word models have been processed for the current parameter frame f k , the parameter frame counter 
variable k is incremented in step S61 . The system then determines, in step S63, whether there are any more parameter 
frames of the input utterance to be processed. This is done by comparing k with the system limit (LIMIT) and the end 
of speech identifier (EOS) in step S63. The system limit is defined by the size of buffer used to store the speech samples 
output from ADC 63 shown in Figure 3. 

If all the parameter frames of the incoming utterance have been processed, then the DP process is complete and 
a backtracking algorithm is used to determine the optimum path : and hence the recognition result. If on the other hand, 
the system determines, at step S63, that there are further parameter frames to be processed, then the system adjusts 
the pruning threshold in step S65 and the processing returns to step S43. The pruning threshold Th is adjusted in step 
S67 to limit the number of valid paths that will be processed in steps S47, S51 and S57 when the next input frame is 
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being processed. 

The processing performed in step S47 of Figure 21 will now be described in more detail with reference to Figures 
22 to 26 for a particular example of a word model. In particular. Figure 22 shows an example word model 201 which 
comprises a sequence of states S 0 to S 9 derived during a training session, and an exit state S D at the end of the word 

s model 201 , the purpose of which will be described below. 

Each state S of the word model 201 has associated therewith a cumulative distance store DfS] which stores the 
cumulative distance of a valid path which ends at that state. In this embodiment, the word model 201 also has associated 
therewith a current active list 203 for the current frame f k which lists, in descending order, the states in the word model 
that are at the end of a valid path for the current frame f k . Therefore, each state in the current active list 203 will store 

10 the cumulative distance of the valid path that ends at that state. In this particular example, the current active list 203 
for the current frame f k lists states S 7 , S 5 , S 4 , S 3 , S 2 , S 1 and S 0 . The states on the current active list 203 will be referred 
to as active states. In this embodiment, the word model 201 also has associated therewith a new active list 205, which 
is completed during the processing performed in step S47 and which lists the states in the word model 201 that will be 
at the end of a valid path for the next frame f k+1 . 

15 The significance of the current active list 203 and the new active list 205 will now be explained with reference to 

Figure 23. In particular, Figure 23 shows seven valid paths pi to p7 which represent seven possible matchings between 
the incoming word and the word model 201 up to the current frame f k . As shown, the seven valid paths pi to p7 end at 
word model 201 states S 7> S 5 , S 4 , S 3 , S 2 , S 1 and S 0 respectively, and it is these end states of the valid paths that are 
listed, in descending order, in the current active list 203. To determine the states that are to be in the new active list 

20 205, i.e. to determine the paths remaining for the next input frame f k+1 , consideration has to be given to the state 
transitions that are allowed from one input parameter frame to the next. 

The maximum amount of time compression of the reference models relative to the incoming utterance is determined 
by the maximum number of states that can be skipped between adjacent frames of the incoming utterance. In this 
embodiment, this is set to two, i.e. the DP process follows the state transition diagram shown in Figure 1 9. The maximum 

25 amount of time expansion of the reference models relative to the incoming utterance is determined by the maximum 
number of consecutive incoming frames which can be matched to the same state. In this embodiment, only three 
consecutive frames can be matched to the same state. To monitor for this situation, each state S has associated 
therewith a self-repetition counter, SELF, which is incremented whenever the same valid path ends at that state from 
one input frame f k to the next f k+1 Therefore, for example, path p5 may propagate along one or all of the dashed paths 

30 207 shown in Figure 23. The other paths pi to p4 and p6 to p7 shown in Figure 23 will propagate in a similar manner 
If two or more paths meet at the same point, then the path having the lowest cumulative distance is maintained and 
the others are discarded. Further, if the cumulative distance of a path is greater than the pruning threshold then this 
path will also be discarded. In this way, new paths are continuously being created whilst others are discarded. The aim 
of the pruning threshold is to limit the number of valid paths that are processed for each input parameter Irame, thereby 

35 placing a limit on the amount of time and memory required for the algorithm. 

Figure 24 shows in more detail the processing steps performed in step S47 of Figure 21 . In particular, in step S71 
a pointer LA is initialised and the cumulative distance stored in the exit state, i.e. D[S D ], of word model 201 is set to a 
very large value, HUGE. The pointer LA is used to point to the last active state that has been placed in the new active 
list 205. Initially, there are no active states in the new active list 205 and so pointer LA is set to point to the exit state 

40 s D . In step S73 the system then checks to see if there are any active states in the current active list 203. In other words, 
a check is made to see if there are any valid paths ending in the current word for the current frame f k . In the present 
example there are seven active states in the current active list 203 and the system processes each in turn. A count 
variable i is provided, which is used to count through the active states on the current active list 203, and which is set 
to zero in step S75 and incremented in step S79 until all the active states in the current active list 203 have been 

45 processed. The system determines whether all the active states have been processed by comparing, in step S81 , the 
value of the count variable i with the number n a of active states in the current active list 203. 

Once all the active states on the current active list 203 have been processed, the new active list 205 generated 
during the processing in step S77 is changed, in step S83, to be the current active list 203 for the next frame f k+1 of 
the input utterance to be processed. In practice this is achieved by swapping the pointers that are used to point to the 

so two active lists. The old current active list then being overwritten during the processing of the next input frame f k+1 . 
Finally in step S85 the last state that was activated and put on the new active list 205, indicated by pointer LA, is stored 
for use in step S57 shown in Figure 21. 

An overview of the processing performed in step S77 will now be given by taking as examples, active states Sj 
and S 5 , which are at the ends of paths p1 and p2 respectively, as shown in Figure 23. Figure 25 shows part of the two 

55 valid paths pi and p2 that end at states Sj and S 5 respectively at the current frame f k . The dashed lines in Figure 25 
show the ways in which each of the two paths pi and p2 may propagate at the next frame f k+1 . As indicated by dashed 
line 213 it is possible for path pi to extend into another word at frame f k+1 Therefore, the cumulative distance of path 
pi (which is stored in active state Sy) is copied into the exit state S D . As indicated by dashed lines 215, 217 and 219 
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path p1 can also propagate to state Sg, state S 8 and state S 7 respectively. Therefore, the cumulative distance of path 
pi is also copied into these states. States S 9 , S Q and S 7 are then added, in descending order, to the new active list 205 
(but not the exit state which is never actually compared with the incoming frames, and is only used to store the minimum 
cumulative distance of ail the paths that leave the word) and the last active pointer LA is set to point to the last state 
added (i.e. state S 7 ). 

Referring to Figure 26a, the new active list 205 is shown after the first state $? on the current active list 203 has 
been processed. As shown, state Sg, state S 8 and state S 7 are in the first three elements of the new active list 205 
respectively, and the last active pointer LA points to state Sy. 

Referring back to Figure 25, as indicated by dashed lines 221, 223, 225 and 227 path p2 can propagate to state 
S 8 , state S 7 , state S 6 and state S 5 respectively. However, the cumulative distance for path p2 is not simply copied into 
each of these states, since two of the states S 8 and S 7 already have a cumulative distance stored therein for the next 
frame f k+1 . For these two states, a comparison is made between the cumulative distances already stored therein and 
the cumulative distances associated with path p2, and the smallest is copied into those two states. In other words the 
cumulative distance stored in S 8 and Sj for the paths shown in Figure 23 and after processing active state S 5 is given 
by minfDfS^.DJSs]). On the other hand, the cumulative distance stored in active state S 5 can be copied directly into 
state S 6 since a cumulative distance for the next frame f k+1 has not previously been stored therein. The two states S 6 
and S 5 (since state S 5 has not repeated twice) are then added to the new active list 205 and the last active pointer LA 
is set to point to state S 5 . 

Referring now to Figure 26b, the new active list 205 is shown after the second active state S 5 on the current active 
list 203 has been processed. As shown, stales S 9 , S 8 , S 7 , S 6 and S 5 are in the first five elements of the new active list 
205 respectively, and the last active pointer LA points to state S 5 . The remaining active states on the current active list 
203 are processed in an identical manner and then the processing proceeds to step S49 shown in Figure 21, where 
the word count is incremented. 

The last active pointer LA is provided so that the system does not have to look at the new active list 205 to identify 
those states which require a comparison and those that do not. If the state is equal to or beyond the state indicated 
by the last active pointer LA then a comparison is required, otherwise the cumulative distance can simply be copied 
into the state. 

The processing performed in step S77 shown in Figure 24 will now be described in more detail with reference to 
Figures 27a and 27b, for the example of the word model 201 shown in Figure 22. The first active state S to be processed 
corresponding to i = 0 in step S77 is state S 7 Therefore, in step S91 of Figure 27a the system checks to see whether 
the cumulative distance for the valid path ending at state S? is less than the pruning threshold Th, i.e. D[S 7 ] is compared 
with Th. If D[S 7 ] is greater than the pruning threshold Th, then this path is discarded and the processing returns to step 
S79 shown in Figure 24. If D[S 7 ] is less than the pruning threshold Th then the processing proceeds to step S92 where 
the variable ACOUNT, which is used to keep count of the total number of active states processed for the current frame 
f k , is incremented. Then the system calculates, in step S93, the local distance between the current active state 
being processed and the current frame f k being processed and adds this to the cumulative distance D[S 7 ]. 

In the present embodiment, the following Euclidean distance equation is used to derive a measure of the local 
distance between the current frame f k and the current active state S: 

d(S,f k ) = \\S-ff (8 ) 

After the cumulative distance D[S 7 ] has been updated in step S93, the system checks to see, in step S95, if the 
valid path which ends at the current active state Sj can leave the current word at the next input frame f k+1 . With the 
above DP constraints this implies determining whether the state three states beyond the current active state S being 
processed, will be beyond the last state in the word model 201. As the state three states beyond the current active 
state S 7 is past the last state S 9 , a pointer j is set to point to the exit state S D at the end of word model 201 in step S97. 
In step S101 the state indicated by pointer j is compared with the state indicated by the last active pointer LA. Since 
this is the firsl active stale in the current active list 203 to be processed, the last active pointer LA will be pointing to 
the exit state S D (see step S71 shown in Figure 24). Therefore the processing proceeds to step S103 where the 
cumulative distance stored in the state pointed to by pointer j, i.e. the exit state S D , is compared with the cumulative 
distance for the valid path pi ending at the current active state S7 being processed. 

The cumulative distance stored in the exit state, i.e. D[S D ], has just been set to the large value, HUGE, in step 
S71 shown in Figure 24, and will therefore be larger than the cumulative distance stored in the current active state Sj 
being processed. Consequently, the processing proceeds to step S105 where D[S 7 ] is copied into D[S D ]. Next in step 
S107 the self-repetition count forthe state indicated by pointer j, i.e. the exit state S D , is set to zero. Then in step S109 
the pointer j is decremented and now points to state Sq, and the processing returns to step S1 01 . 
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This time the state indicated by pointer j (state S 9 )is before the state indicated by the last active pointer LA (state 
S D ) and therefore the processing proceeds to step S111 shown in Figure 27b. In step S111 the system checks to see 
if the state pointed toby pointer j, i.e. state S 9 , is equal to the current active state S7 being processed. It is not, therefore, 
the processing proceeds to step S113 where the cumulative distance stored in state S 9 is made equal to the cumulative 

5 distance stored in the current active state Sy. In other words, the cumulative distance of path pi is copied into state Sq. 
Then in step S115 state S g is added to the new active list 205 shown in Figure 22. In step S117 the self-repetition 
counter associated with state S 9 is reset to zero, and in step S11 9 the pointer j is decremented and now points to state 
S s . The processing then returns to step S111 and state S 8 is processed in a similar manner. 

After state S 8 has been processed in steps S113, S115 and S117, j is decremented in step S119 and now points 

10 to state S 7 which is also the current active state being processed. Therefore at this point, the processing proceeds to 
step S121 where the self-repetition count associated with state Sy is checked to see if the valid path ending at state 
S 7 has ended there for the past two frames of the input utterance. If the self-repetition count associated with state S 7 
is equal to two, then state S7 is not added to the new active list 205 and the processing proceeds to step S123 where 
the last active pointer LA is set to point to the current active state plus one, i.e. to state S 8 . This routine ensures that 

*5 if the self-repetition count associated with the current active stale is equal to two, then the valid path which ends at the 
current active state is prevented from propagating to the same state at the next frame f k+1 . In the example of the paths 
shown in Figure 23, path pi ending at state Sy for the current frame f k came from state S 6 and therefore the self- 
repetition count will be equal to zero. Consequently state S 7 is added to the new active list 205 in step SI 25. The self- 
repetition count for state Sy is then incremented in step S127, and the last active pointer LA is set to point to the current 

20 active stale, i.e. state Sy, in step S129. 

After step S129 or step S123 the processing proceeds to step S131 where the cumulative distance stored in the 
current active state S 7 is compared with the minimum cumulative distance MINSCORE for all of the valid paths, in all 
the words, that have been processed for the current frame f k . If the cumulative distance stored in state Sy is less than 
MINSCORE then MINSCORE is replaced by the cumulative distance stored in state Sy in step S1 33, and the processing 

25 returns to step S79 shown in Figure 24. If the cumulative distance stored in MINSCORE is smaller than the cumulative 
distance associated with the current state S 7 , then the processing returns to step S79 shown in Figure 24. Upon 
returning to step S79 the count variable i is incremented and the next active state in the current active list 203, i.e. 
state S 5 , is processed in step S77. 

Active state S 5 is processed in a similar manner to active state Sy described above. In particular, provided the 

30 cumulative distance of the valid path ending at state S 5 is less than the pruning threshold Th, then in step S93, the 
system calculates the local distance between the current active state S 5 and the current frame f k being processed and 
adds this to the cumulative distance stored in the current active state S 5 . Then in step S95 the system determines that 
the path p2 ending at the current active state S 5 cannot extend into another word at the next frame f k+1 due to the 
above DP constraints. In other words three states beyond state S 5 is not equal to or beyond state S D , and therefore 

35 the processing proceeds to step S99 where the pointer j is set to point to state S 5 plus three, i.e. state S 8 . The state 
indicated by pointer j is then compared with the state pointed to by the last active pointer LA in step S101 . 

Last active pointer LA points to state Sy and pointer j points to state S 8 . Therefore, the processing proceeds to 
step S103 where the cumulative distance already stored in state S 8 (as a result of the processing of active state Sy) 
is compared with the cumulative distance stored in active state S 5 . If the cumulative distance stored in S 8 is greater 

40 than the cumulative distance stored in active state S 5 then it is replaced by the cumulative distance stored in active 
state S 5 . Then the self-repetition counter associated with state S 6 is reset to zero in step S107 and the pointer j is 
decremented in step S1 09 so that it now points to state Sy. The processing then returns to step S101 where a similar 
processing is performed. 

This recursive processing routine is performed on all the current active states in all the reference words known to 
45 the system. 

After processing each word in the above manner for the current frame f k , each node in the language model 21 is 
processed in turn. As described above the language model 21 determines the sequences of words that are allowable. 
This information is defined by the nodes and in particular by the words that are connected to the input and output 
thereof. The processing of the nodes in step S51 of Figure 21 ensures that valid paths only propagate through allowed 
50 sequences of words. The processing performed in step S51 will now be described in more detail with reference to. 
Figure 28. 

Initially, prior to processing any of the nodes the local distance between the frame representative of background 
noise and the current frame f k (i.e. d(noise,f k )) is calculated in step S1 51 . Then in step S1 53 a node pointer v is initialised 
to point to the start node N 0 . Then in step S 155 the cumulative distance stored in the node pointed to by the node 
55 pointer v, i.e. D[v], is compared with the pruning threshold Th. If D[v] is less than the pruning threshold Th then the 
processing proceeds to step S1 57 where d(noise,f k ) is added to the cumulative distance stored in the current node v 
being processed. Then in step S159 the system compares D[v] with the value stored in the minimum value store 
MINSCORE, and copies it into MINSCORE in step S161 if it is smaller. Then the count ACOUNT (which indicates the 
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number of active states and nodes that have been processed for the current frame) is incremented in step S163 and 
the processing proceeds to step S165. Returning to step SI 55, if D[v] is greater than the pruning threshold Th then it 
is set to the large value HUGE in step S167 and the processing proceeds to step S165. 

The processing performed in step S165 and step S1 68 will be explained for the example node N shown in Figure 
29, which has the three words "get", "save" and "load" connected to its input and the words "an" and "the" connected 
to its output. Although the generation of such a node is not possible using the procedure shown in Figure 17b, this 
example is chosen to illustrate that the dynamic programming process will work for more complex language models. 
In particular, finite state grammars where nodes like the one shown in Figure 29 are commonplace. 

In step S165 the system determines the minimum of all the cumulative distances stored in the exit states for the 
words connected to the input of node N, i.e. the exit states of words "get", "save" and "load". For the general case, this 
calculation is represented by: 



20 



where l w [v] represents all the words connected to the input of node v. After the system has determined this minimum 
cumulative distance for node N, it is copied into the cumulative distance D[N] stored in node N if it is smaller than the 
cumulative distance already stored there. In effect, this is a determination of whether there is a valid path coming from 
one of the words connected to the input of the node which has a smaller cumulative distance than the cumulative 
distance of the path which is still propagating in the node. 

It is possible for valid paths to propagate within the node because it is possible that there are gaps before, between 
and at the end of the words in the phrase which match with the background noise frame. This possibility of a valid path 
remaining within a node from one input frame to the next is represented by the arrow 231 shown in Figure 29, which 
leaves and returns to node N. Unlike the states of the word models, a path may remain within a node for any number 
of consecutive input frames. After the system has performed the processing of step S165 the cumulative distance 
stored in node N is copied, in step S168, into the temporary store INSCORE represented by boxes 233 and 235 for 
words "an" and "the" respectively, if it is smaller than the value already stored there. A comparison must be made since 
it is possible that a word may be connected to the output of more than one node, and it is only the path having the 
minimum cumulative distance that is propagated into the connecting word. The cumulative distance stored in the tem- 
porary store INSCORE of a word is used to update the entry states of that word during the processing in step S57 
shown in Figure 21. 

The system then checks, in step S169, whether D[v] equals the large value HUGE. If it does, then this indicates 
that no valid paths will end or pass through the current node v into a word connected to it at the next frame f k+v If D 
[v] is less than the large value HUGE, then a valid path will either end at the node v or passes through it into a word 
connected to it, at the next frame f k+1 . Therefore the counter PACOUNT, which represents the number of potentially 
active states (and nodes) at the next input frame f k+1 , is incremented in step S171 since the silence state associated 
with that node may be active at the next input frame f k+1 . The node pointer v is then incremented in step S173 and will 
now point to the next node in the language model 21 . The system then checks to see if all the nodes in the language 
model 21 have been processed in step S1 75, by checking to see if the node pointer v indicates a node which is beyond 
the end node N n in the language model 21 . If the system has not finished processing all the nodes, then the processing 
returns to step S155, whereas if all the nodes have been processed then the processing returns to step S53 shown in 
Figure 21. 

The processing performed in step S57 shown in Figure 21 will now be described in more detail with reference to 
Figures 30 and 31 , for the word model 201 shown in-Figure 22. Referring to Figure 30, in step S181 the system checks 
to see if the cumulative distance stored in INSCORE equals the large value HUGE. If it does then this means that no 
valid paths will be entering this word at the next time point. Therefore, this word does not need to be processed again, 
so the processing proceeds to step S207 where the number of active slates for the next input frame f k+1 (which are 
now stored in the current active list 203 due to step S83 shown in Figure 24), is added to the count PACOUNT. The 
processing then returns to step S59 shown in Figure 21 where the word count is incremented so that the next word 
model can be processed. 

If on the other hand, INSCORE is not equal to the large value HUGE, then this means that a valid path has left a 
preceding word and may enter the current word being processed. Therefore, the states of the current word model 
which can be reached by a path extending from another word model (which will be referred to as the entry states) must 
ss be updated using the cumulative distance stored in INSCORE. In the present embodiment wrth the above DP constraints 
the entry states are states S a and S 2 . This updating procedure is achieved in the following manner. Firstly in step 
S183 the system checks to see if the word model representative of the current word being processed contains more 
than three states (not including the exit state). If there are more than three states, then the state pointer j is set to point 
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to state S 2 in step S185. If on there other hand there are less than three states in the current word, then the state 
pointer j is set, in step S187, to point to the exit state S D at the end of the word being processed. After the state pointer 
j has been set to point to either state S D or state S 2 in steps S187 or S185 respectively, the processing proceeds to 
step S189 where the state indicated by pointer j is compared with the state indicated by the last active pointer LA. 

As with the processing performed in the sequence of steps shown in Figures 27a and 27b, if the state indicated 
by pointer j is beyond the state indicated by the last active pointer LA, then a comparison has to be made between the 
cumulative distance already stored in that state and the cumulative distance stored in INSCORE. 

For the example DP paths shown in Figure 23, path p7 can propagate to states S 1( S 2 and S 3 at the next frame 
f k+1 but not to state S 0 , since path p7 has ended at state S 0 for the preceding two frames. Therefore, the last active 
pointer LA will point to state S v 

Figure 31 shows the entry states (i.e. the first three states) of the word model 201 shown in Figure 22. As shown, 
the last active pointer LA points to state S v Since there are more than three states in the word model 201 the state 
pointer j will point to state S 2 . Therefore, the system will determine, in step S189, that the state indicated by pointer j 
is beyond the state indicated by the last active pointer LA, i.e. state S n , and therefore, the processing proceeds to step 
S1 91 In step S1 91 the system compares the cumulative distance stored in state S 2 with the cumulative distance stored 
in the temporary store INSCORE associated with word model 201. The store INSCORE, for word model 201, is rep- 
resented by rectangular box 241 shown in Figure 31. If the cumulative distance stored in INSCORE is smaller than 
the cumulative distance stored in state then it is copied into state S 2 in step S193. Then in step S195 the self- 
repetition count for state Sg is reset to zero and the processing proceeds to step S1 97. If the cumulative distance stored 
in INSCORE is greater than the cumulative distance stored in state S2, then the cumulative distance stored in state 
S 2 is unchanged and the processing proceeds to step S197 where the pointer j is decremented so that it now points 
to state S v The processing then returns to step S189 and the same processing is performed to state S v 

After processing state S-, the pointer j is decremented again in step S1 97, and will now point to state S 0 . Therefore, 
the processing will proceed to step S1 98 after step S1 89, where the system checks to see if there are any more states 
to be processed. Since state S 0 is still to be processed, the system proceeds to step S1 99 where the cumulative 
distance stored in INSCORE is copied into state S 0 . No comparison of cumulative distances has to be performed for 
state S 0 as this state is before the last active state pointed to by the last active pointer. The system then adds, in step 
S201 state S 0 to the current active list (which was the new active list 205 prior to step S83 in Figure 24) and decrements 
the pointer j so that it now points to state S.., . The processing then returns to step S1 98 where the system determines 
that there are no more entry states in the current word to be processed. The processing then proceeds to step S205 
where the cumulative distance stored in the corresponding temporary store INSCORE is reset to the large value HUGE. 
The number of states on the current active list is then added, in step S207 to the count PACOUNT and the processing 
returns to step S59 shown in Figure 21. 



35 Pruning 



Referring to Figure 21, if in step S63the system determines that there are more input frames to be processed, 
then the processing proceeds to step S65 where the pruning threshold Th is adjusted. The aim of using pruning is to 
limit the number of DP paths that propagate from one time point to the next. In particular, the present embodiment aims 
to adjust the pruning threshold so that the number of active states that are actually processed remains essentially 
bounded within predefined limits, which are dictated by the amount of working memory and processing time available. 
Furthermore, the present embodiment also aims to achieve this without the need for expensive computational over- 
heads. In this embodiment, the pruning threshold is determined by adding a variable differential value (PRUNING) to 
the overall minimum cumulative score MINSCORE determined for the input frame just processed, i.e. the pruning 
threshold is given by: 

Th = MINSCORE + PRUNING (10) 



One way of ensuring that only a set number of active states are processed for each input frame is to sort the active 
states that are on all the active lists for the input frame about to be processed in order of increasing cumulative distances 
stored therein, and then only processing the desired number beginning with the one with the lowest cumulative distance. 
However, this technique requires a large amount of computational time to sort out the active states. Rather than per- 
forming this computationally expensive sorting, the technique employed in the present embodiment makes use of the 
information available after processing the last input frame. In particular, in this embodiment a differential value (PRUN- 
ING) is varied in dependence upon the number of states that are potentially active (which is stored in PACOUNT) for 
the next input frame to be processed, in order to maintain the number of states that will actually be processed, to be 
between two thresholds. The manner in which the pruning threshold Th is adjusted will now be described in more detail 
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with reference to Figure 32. 

In step S211 the system compares the number of states that are potentially active for the next frame to be processed 
(which is stored in PACOUNT) with a state threshold (STATETH), which is set- to be less than but close to an absolute 
maximum state threshold determined by the amount of working memory available. If the value stored in PACOUNT is 
less than STATETH then this means that all the potentially active states can be processed, and therefore, the differential 
value PRUNING used at the last time point can be increased. Therefore, in step S213 an adjustment constant dpi is 
added to the existing differential value, PRUNING. The value of dPl is set to be larger than any reasonable local 
distance, so that most, if not all, of the potentially active states will be processed. 

The value stored in PRUNING is then compared with a high pruning threshold, HIGHPRTH in step S21 5. An upper 
limit is placed on the differential value PRUNING as it is assumed that there is a maximum differential value above 
which there is never any need to go. If the value stored in PRUNING is less than HIGHPRTH then the processing 
proceeds to step S219. If the value stored in PRUNING is greater than HIGHPRTH then PRUNING is set to equal 
HIGHPRTH in step S21 7. After step S21 5 or step S21 7 the system sets the pruning threshold Th to equal the minimum 
cumulative distance of all the remaining valid paths, i.e. MINSCORE, plus the differential value PRUNING. The process- 
is ing then returns to step S43 shown in Figure 21 . 

If at step S211 the system determines that the number of potentially active states, PACOUNT, for the next frame 
is greater than STATETH, then the system compares, in step S221 , the number of states that were active and processed 
during the processing of the last input frame (which is stored in ACOUNT) with a low state threshold, LOWSTTH. The 
value of LOWSTTH is set to try and ensure that if ACOUNT is less than LOWSTTH, then it will be possible to process 
all the potentially active stales for the next input frame without taking too much lime or memory. Therefore, if ACOUNT 
is less than LOWSTTH, then the processing passes from step S221 to step S21 3 where the differential value PRUNI NG 
is adjusted and the processing proceeds as described above. If, on the other hand, ACOUNT is greater than LOWSTTH 
then there is no guarantee that if all the potentially active states are processed then this will not take too much time or 
memory to process. Therefore, it may be necessary to reduce the differential value PRUNING. 

In order todetermine whether the differential value PRUNING needs to be reduced, the system compares ACOUNT 
with STATETH in step S223. If ACOUNT is less than STATETH then the system checks to see if the differential value 
PRUNING is equal to HIGHPRTH. If it does equal HIGHPRTH then this indicates that the system has been trying to 
process all the active states, and that therefore, it is unlikely that the number of active states that will be processed for 
the next input frame will result in the process taking too long or too much memory. Therefore, the differential value 
PRUNING is not changed and the processing passes to step S219 where the pruning threshold is set to equal MIN- 
SCORE plus the differential value PRUNING. If on the other hand, the differential value PRUNING is not equal to 
HIGHPRTH (in which case it must be less than it), then it is possible that the number of active states that will be 
processed for the next input frame will take too long or too much memory. Therefore, the actual number of active states 
that will be processed must be calculated. This is performed in step S233 using the pruning threshold set in step S231 
35 which uses an unchanged differential value PRUNING. 

Returning to step S223, if the system determines that ACOUNT is greater than STATETH then the differential value 
PRUNING is reduced by the adjustment constant dpi in step S225. After the differential value PRUNING has been 
decreased in step S225, the system determines in step S227 whether the differential value PRUNING is less than a 
low pruning threshold, LOWPRTH. A low pruning threshold is used to ensure that the number of active states that will 
40 be processed for the next input Irame, will be greater than a set emergency state threshold, EMGSTTH. The reason 
for this is that it has been found that the dynamic programming process fails if it is pruned too heavily If the differential 
value PRUNING is less than the low pruning threshold LOWPRTH, then it is made equal to LOWPRTH in step S229, 
and the pruning threshold Th is set, in step S231 , to equal MINSCORE plus the adjusted differential value PRUNING. 
Subsequently, in step S233 the system counts the number of active states that will be processed for the next input 
45 frame. This is achieved by comparing the cumulative distances stored in all the active states and the cumulative dis- 
tances stored in all the nodes with the newly determined pruning threshold Th. 

This total number (n^) represents the total number of active states and nodes that will be processed for the next 
input frame. If this total number n^ is less than the emergency state threshold, EMGSTTH, then the pruning threshold 
has been set too low and the processing returns to step S21 3 where the differential value PRUNING is increased and 
50 the pruning threshold Th is reset. If n M is not less than EMGSTTH then it is compared with LOWSTTH in step S237. 
If is greater than LOWSTTH then this implies that the pruning threshold Th set in step S231 is acceptable and the 
processing returns to step S43 shown in Figure 21 . If on the other hand, is less than LOWSTTH, then the pruning 
threshold can be increased, and so a second adjustment constant dp2 is added to the differential value PRUNING in 
step S239, prior to the pruning threshold Th being reset in step S219. In this embodiment the second adjustment 
constant dp2 is set to equal half the adjustment constant dpi. 

As those skilled in the art will realise, the above method of varying the pruning threshold is not computationally 
expensive, yet it allows the pruning threshold to be adjusted in such a manner that the number of active states that 
are processed at each time point is bounded, so that the allocated processing time and memory are not exceeded. 
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After all the frames in the input sequence have been processed using the sequence of processing steps illustrated 
in Figure 21 a backtracking routine is required to determine the exact path taken by the optimum path determined by 
the dynamic programming process. In this embodiment the backtracking routine traces through backpointers which 
indicate the sequence of words through which each path propagates. The details of the way in which the backtracking 
$ routine is performed, and the way in which the pointers are generated are well known to those skilled in the art of 
speech processing, and will not be described further. 

Initialisation 

10 Before the system attempts to recognise an input utterance, the system thresholds and variables which are used 

during the recognition process must be initialised. This is achieved in the following manner Firstly the cumulative 
distance stored in the start node N 0 is set to zero and the cumulative distance stored in all the other nodes is set to 
equal the large value, HUGE. Then the counter which counts the number of potentially active states, PACOUNT, as- 
sociated with each word model is set to zero; the last active pointer associated with each word model is set to point to 

*s the end state S D of that model; and the temporary store INSCORE associated with each word model is set to the large 
value, HUGE. All the nodes are then processed so that the minimum of the cumulative distances of all the nodes 
connected to the input of a word is, copied into the temporary store INSCORE associated with that word. This ensures 
that the temporary store INSCORE of each word connected to the start node N 0 is set to zero. Finally, the value stored 
in INSCORE of each word is used to activate and initialise the entry states of each word model. The processing steps 

20 io initialise the entry states of each word model are identical to the processing steps used to update the entry states 
described above with reference to Figure 30. The pruning threshold and the differential value PRUNING are also 
initialised prior to the processing of the first input frame. In particular, the pruning threshold Th is set to the large value, 
HUGE, and the differential value PRUNING is set to equal the high pruning threshold, HIGHPRTH. 

2S Flexible dynamic proqrammin alignment 

A brief description is given above with reference to Figures 13 to 16, of the way in which the word models are 
generated in this embodiment. In particular, isolated word models are first generated for the words contained in a 
phrase by aligning the sequence of parameter frames corresponding to the phrase with the sequences of parameter 

30 frames corresponding to the words when spoken in isolation contained within the phrase, using a flexible dynamic 
programming alignment process. This flexible alignment process will now be described in more detail for the training 
phrase "get an image", when no word model for the words in the phrase exists yet. 

Figure 33 shows the sequence of parameter frames 152 which corresponds to the utterance of the phrase "get an 
image" and the sequences of parameter frames 1 58,1 60 and 1 62 corresponding to the utterances of the isolated words 

35 "get", "an" and "image" respectively. Since some of the parameter frames in the sequence of parameter frames 152 
will correspond to background noise or silence, nodes 251 , 253, 255, 257 are provided between the isolated words 
and at the beginning of the first word and at the end of the last word contained in the phrase. These nodes act in a 
similar manner to the nodes in the language model shown in Figure 17a, and take care of the situation where a current 
parameter frame of the sequence of parameter frames 152 being processed, corresponds to silence or background 

40 noise. This possibility is illustrated in Figure 33 by the silence frame f^ 1 (which is the noise model 23 shown in Figure 
10) at nodes 251 , 253, 255 and 257. 

Although some of the frames at the beginning and at the end of the sequences of parameters frames 1 58,1 60 and 
162 will correspond to silence or background noise, the parameter frames in the sequence of parameter frames 152 
which correspond to silence or background noise should match better with the silence frame f 3 * 1 stored in the nodes 

45 251 , 252, 255 and 257 than the frames corresponding to silence in sequences 158, 160 and 162. This is because the 
silence frame f si1 represents an average of all silence frames, and therefore on average, the variation between the 
frames in sequence 152 corresponding to silence and the silence frame I s ' 1 should be less than the variation between 
the frames corresponding to silence in sequence 152 and those corresponding to silence in sequences 158, 160 and 
162. 

50 The way in which the flexible alignment process is carried out is similar to the way in which the input speech is 

aligned with the stored reference models, as described above with reference to Figures 18 to 32. In particular the 
general processing steps of the flexible alignment process follow those shown in Figure 21 , using the sequences of 
parameter frames 1 58, 1 60 and 1 62 as reference models, the nodes 251 , 253, 255 and 257 and the frames of sequence 
1 52 as input frames. In order to avoid confusion, the parameter frames of the sequences 1 58, 1 60 and 1 62 representing 

ss the words when spoken in isolation will be referred to as states. Like the states of the reference models used during 
recognition of an unknown input utterance, these states have an associated cumulative distance store for storing the 
cumulative distance of the dynamic programming path which ends at that state for the current frame of the sequence 
152 being processed. 
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The main difference between the flexible alignment process and the alignment process used during recognition 
of an unknown input utterance is that with the flexible alignment: 

(i) each dynamic programming path can enter a word at any position (and not only in one of the entry states); and 

(ii) each dynamic programming path can exit a word from any state therein. 

The way in which the flexible alignment process operates for the above example will now be explained by consid- 
ering the first few parameter frames of the sequence of parameter frames 152. Before processing the first frame, 
however, the cumulative distance scores associated with the nodes and the states in the word models are initialised! 
This initialisation procedure is similar to the initialisation procedure performed prior to attempting to recognise an un- 
known input utterance, as described above. In particular, the cumulative distance stored in the start node, ie. node 
151 , is set to zero and the cumulative distance stored in all the other nodes is set equal the large value, HUGE. The 
cumulative distance scores of the states in words W1, W2 and W3 are then updated using the cumulative distance 
scores stored in the nodes connected to the input of the words. This will ensure that a dynamic programming path can 
be started at each state of the first word W1 and at the first node 151 when the frame f 0 pi is processed. 

After initialisation, the first frame f 0 P1 is processed with respect to each word Wl, W2 and W3 in turn. However, 
since the cumulative distance associated with the states in words W2 and W3 will have the value, HUGE, the first 
frame will only be processed with respect to the states in the first word Wl . When processing the first frame with respect 
to word W1 , the distance between frame f 0 P1 and each state in word W1 is stored in the respective cumulative distance 
store associated with that state. The flexible alignment process then processes the nodes 251, 253, 255 and 257 in 
turn, using the processing steps shown in Figure 28. Finally, the processing of the first frame f 0 Pl is completed by 
updating the cumulative distance scores of the states in words W1 , W2 and W3 using the results of the node processing. 
The updating procedure is similar to that shown in Figure 30 except all the states in the words are updated and not 
just the entry states (ie. the first three states). 

Once the first parameter frame of sequence 152 has been processed, the second parameter frame f-, pi is proc- 
essed in order to propagate the dynamic programming paths started by the processing of the first parameter frame 
f 0 pi . As with the dynamic programming method used during recognition of an input utterance, the states in each word 
W1 , W2 and W3 are processed in reverse sequential order, using in this embodiment similar propagation constraints 
as those described with reference to Figures 19 and 20. The only difference is that each dynamic programming path 
is also allowed to exit a current word from any of its states, and not just from the last three states as is the case during 
recognition of an unknown input utterance. Once the words W1, W2 and W3 have been processed using the second 
parameter frame the nodes 251 , 253, 255 and 257 are processed in order to update the dynamic programming 
path which is currently propagating within each node. Once this had been done, each of the words W1, W2 and W3 
is processed again in order to update the dynamic programming paths in order to take into account the results of the 
3S node processing. 

The remaining parameter frames in the sequence of parameter frames 1 52 are then processed in turn in a similar 
manner. Once all the parameter frames in the sequence 152 have been processed, the dynamic programming path 
with the lowest cumulative score is determined. In order to identify the beginning and end frames within the sequences 
of parameter frames 1 58, 1 60 and 1 62 which bound those parameter frames which represent the corresponding words 
(and not silence), a record is made of the progress of each dynamic programming path during the flexible alignment 
process. 

In particular, whenever a dynamic programming path enters a word, either from a preceding word or from the node 
in front. of the word, the state into which that dynamic programming path enters is recorded and associated with that 
path. Similarly, when a dynamic programming path exits a word then the state from which it exits is recorded, provided 
the score associated with that path is lower than the score associated with all previous dynamic programming paths 
which have exited from that word. Therefore, once the last parameter frame in the sequence of parameter frames 152 
has been processed and the dynamic programming path having the best score is identified, approximate beginning 
and end points of the words within the sequence of parameter frames 158, 160 and 162 can be identified by looking 
at the record associated with the identified dynamic programming path. 

As those skilled in the art will appreciate, the above description of the flexible alignment process is particular to 
the situation where no word model exists for each word contained in the input phrase. However, since the training of 
the reference models is designed to be incremental in nature, ie. such that the user can train the system at his con- 
venience, the situation will sometimes arise that a word model for a word in an input phrase will already exist. In this 
case : during the alignment between the phrase and the individual words, a hybrid type dynamic programming alignment 
process is employed which uses a standard type dynamic programming alignment process for words that already have 
a word model, and a flexible dynamic programming alignment process for the other words which do not yet have a 
word model. 

As mentioned above with reference to steps S25 and S26 in Figure 14, once the isolated word models for the 
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unknown words in a phrase have been determined, they are aligned with the sequence of parameter frames of the 
input phrases containing that word, and word models are generated from the result. 

Word Model Adaptation 

5 

Another feature of the speech recognition system according to this embodiment is that the word models 19, the 
noise model 23 and the language model 21 shown in Figure 1 0 can be updated and even modified by the build/update 
module 91 . Therefore, the stored word models 1 9 can be modified or adapted by the input speech of a different user. 
Figure 34 is a flow chart which illustrates one method of how the stored word models 19 can be adapted to a 

10 different user. In particular, in step S251 the the new user inputs a known word or phrase into the system via the 
microphone 7 and the keyboard 3. The build/update module 91 therefore has the sequence of parameter frames cor- 
responding to the utterance from the new user and the corresponding text entered via the keyboard 3. The system 
then aligns, in step S253, the input utterance with the existing word models of the words which are known to be in the 
utterance using a dynamic programming routine. The dynamic programming routine aligns the parameter frames of 

*s the input utterance with the states of the appropriate word models. The system then directly replaces, in step S255, 
the states of the word models with the sequence of parameter frames which are aligned therewith. If the new user then 
decides, in step S257, to input another phrase, then the processing returns to step S251, and the same routine is 
performed again for the next input utterance. If the new user decides at step S257 that no more phrases are to be 
adapted then the processing ends. 

20 Figure 35 is a flow chart which illustrates a second method of how the stored word models 1 9 can be adapted for 

a different user. In particular, in step S261 the new user inputs a known word or phrase into the system, a number of 
times via the microphone and once via the keyboard. The build/update module 91 therefore has a plurality of sequences 
of parameter frames, each corresponding to the utterance of the known word or phrase by the new user, and the 
corresponding text entered via the keyboard 3. The system then aligns, in step S263, each input utterance with the 

2$ existing word models of the words which are known to be in the utterance, using a dynamic programming routine. 

The dynamic programming routine aligns the parameter frames of each input utterance with the states of the 
appropriate word models. The system then replaces, in step S265, the states of the word models with the average of 
the parameter frames which are aligned therewith. If a state of a word model has not been aligned with any of the 
parameter frames of the utterances then, in this embodiment, the system interpolates between or extrapolates from 

30 neighbouring replaced states. If the new user decides, in step S267, to adapt another phrase, then the processing 
returns to step S261, and the same routine is performed again for the next phrase. If the new user decides at step 
S267 that no more phrases are to be input then the processing ends. Therefore, as wilt be apparent to those skilled 
in the art, the new user can adapt the existing word models incrementally at his convenience. Additionally, the new 
user can also add new words or phrases to the system in the manner described above. 

35 

Alternative Embodiments 

A number of modifications can be made to the above speech recognition system without departing from the in- 
ventive concept of the present invention. A number of these modifications will now be described. 

40 Although in the above embodiment, the whole utterance is received before it is processed, the system can run 

incrementally whereby as the speech is received it is processed. In such an embodiment, an input buffer would still be 
required, but it would only need to be able to store incoming speech corresponding to one frame : i.e. 20 milliseconds 
of speech. As those skilled in the art will realise, in order for this system to work, the entire processing of the frame of 
input speech (by the preprocessor and the recognition block), must be finished before the next frame of input speech 

45 js ready to be processed. With the above frame rale and frame duration, this means that the time taken to process a 
frame of input speech must be less than ten milliseconds. This can be achieved with current state of the art processors. 

In addition, the power parameter in each frame of the input utterance would have to be normalised in a different 
manner. One way of normalising the power in such an embodiment would be to use an adaptive normalisation factor 
which would be adapted based upon the power of the input speech over, for example, the previous twenty input frames. 

so In the first embodiment, the states of the word models which were at the end of a dynamic programming path were 

listed in an active list associated with that word model. In an alternative embodiment a single global active list could 
be provided in which all the active states of all the word models would be listed. In such an alternative embodiment, 
information would have to be stored associated with the global active list, for identifying which word models the particular 
active states belong to. 

55 In the first embodiment, the states of the word models correspond in time duration to the frames of the input speech 

to be recognised. In an alternative embodiment, each state of a word model could be equivalent in time duration to, 
for example, three consecutive frames of the input speech. In such an alternative embodiment, the input frames would 
be averaged in groups of three and then aligned with the states of the word models. 
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In yet another alternative embodiment, the word models could be statistical models, for example Hidden Markov 
models, well known to those skilled in the art of speech recognition. In such an embodiment, rather than determining 
the minimum cumulative distance between the input utterance and the sequences of word models, the maximum prob- 
ability that the input sequence was generated by a particular sequence of Hidden Markov models would be determined. 
In such an embodiment, the Hidden Markov models would be generated in a similar manner to the continuous reference 
models generated in the first embodiment. In particular, an isolated reference model for a word would be generated 
by comparing an utterance of the word with one or more utterances of phrases containing the word. The isolated 
reference model would then be used with a plurality of example phrases, which contain the word, to generate the mean 
parameter frames and the covariance matrices of the states of the Hidden Markov Model, and to generate the transition 
probabilities between the states. The way in which this would be achieved, would be apparent to those skilled in the 
art of speech recognition. 

In the first embodiment, the reference models used corresponded to whole words. As those skilled in the art will 
realise, this is not essential. The reference models could correspond to parts of words, e.g. syllables, to a plurality of 
words or even to individual phonemes. However, the disadvantage of using reference models which correspond to 
phonemes is that the system becomes language dependent. Further, reference models which are equivalent to whole 
words are preferred to those equivalent to whole phrases because there is a potential for time and computational 
savings. In particular, by modelling the words within phrases and by using a language model, it is possible to teach 
the system many different phrases using only a handful of words. If on the other hand : the reference models corre- 
sponded to the whole phrases, then a reference model would be required for each of the different phrases to be learnt 
by the system. In addition to this advantage, the use of reference models which correspond to words also increases 
the system's flexibility to gaps between the words in the phrase. This is possible because of the environment model 
which can appear at the beginning or end of the phrase and also between the words in the phrase. 

In yet another alternative embodiment, the reference models could be compressed if consecutive frames of the 
model are similar. If this situation arises then the consecutive similar frames would be replaced by a single frame. In 
2S such an embodiment, the constraint placed on the dynamic programming process, that consecutive frames of the input 
utterance cannot be aligned with the same state of a word model more than twice, would have to be removed. 

In the language model shown in Figure 17, if a word can be followed by two different words, then no preference 
is placed on which of the two words will follow that word. In an alternative embodiment, it would be possible to weigh 
some sequences of words more favourably than others. For example, for the phrases illustrated in Figure 17a, it may 
30 be known that the phrase "make it more ..." (followed by a colour) is more common than the phrases "make it smaller", 
or "make it larger" or "make it brighter". Therefore, the transition from node N 7 to node N 8 is made stronger compared 
to the transition from node N 7 to the end node N n . This can be achieved by using weighing factors which weigh the 
cumulative distances being propagated from node N 7 to the input of words "more", "smaller", "larger" and "brighter". 
As those skilled in the art will realise, the language model used to define the allowed sequences of words does 
3S not have to be a Bigram model, but could be any known type of language model, for example a finite state grammar 
model. If the type of language model used is changed, then some modifications would have to be made to the dynamic 
programming matching process described above, but such modifications would be apparent to those skilled in the art 
of speech recognition. However, the essential features of the matching process would remain unchanged, as these 
are designed to be suitable for use in any pattern matching process. 
40 In the first embodiment, at least two phrases which contain a word had to be input into the system before a reference 

model for that word could be generated. This is a preferred mode of operation, and word models could be generated 
for each word from only a single example phrase containing that word. However, in such an embodiment, the reference 
models will be less representative of that word when used in any given phrase. Additionally, in the training method 
used in the first embodiment, once a reference word model is determined for a word the word model is not changed 
regardless of whether subsequent input training phrases contain that word. In an alternative embodiment, it would be 
possible to update existing word models during the training session, using input phrases which contain examples of 
the words for which there are already word models. 

When the user is training the speech recognition system, and inputs a phrase containing a number of words which 
have already been input in isolation, the system does not prompt the user to input those words in isolation again. In 
an alternative embodiment, the system could prompt the user for those words again, and could perform a consistency 
check to ensure that the two utterances of the word do not significantly differ. 

In the first embodiment, when the reference models are being trained or adapted, the user has to input the text 
and then input the corresponding voice command. As those skilled in the art of speech recognition will realise, this is 
not essential. Instead of entering text, the user could simply press a corresponding key/combination of keys on the 
keyboard, facsimile machine, photocopier etc. For example, when training the system for use in a photocopier, when 
entering the voice command "copy" the desired machine response can be input by the user simply pressing the copy 
button. 

In addition, it will be apparent to those skilled in the art of pattern matching, that the method of implementing the 
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dynamic programming matching process and the reference model generation and adaptation processes described 
above, could also be used for matching other types of patterns. For example, it is envisaged that the above described 
pattern matching process could be used in handwriting recognition or other pattern matching techniques. 

Although a continuous word speech recognition system is described in the first embodiment described above, it 

5 will be apparent to those skilled in the art that many features of the system described could equally apply to other kinds 
of speech recognition systems. For example, the way of determining the isolated word models, and the isolated word 
models referred to above, could be used in an isolated word speech recognition system. Similarly, many features of 
the way in which the dynamic programming process is carried out, and the way in which the pruning threshold is 
adjusted, could be used in any speech recognition system where the reference models correspond to any part of 

10 speech, e.g. phonemes, syllables, etc. 

The speech recognition system described in the first embodiment can be used in conjunction with many different 
software applications, for example, a spreadsheet package, a graphics package, a word processor package etc. If the 
speech recognition system is to be used with a plurality of such software applications, then it might be advantageous 
to have separate word and language models for each application, especially if the phrases used in each application 

*5 are different. The reason for this is that as the number of word models increases and as the language model increases 
in size, the time taken for the system to recognise an input utterance increases. Therefore, by having separate word 
and language models for each application, the speed of the speech recognition system can be maintained. Additionally, 
several word and language models could be used for each application. 

Additionally, as those skilled in the art will appreciate, the above speech recognition system can also be used in 

20 many different types of hardware. For example, apart from the obvious use in a personal computer or the like, the 
speech recognition system could be used as a user interface to a facsimile machine, telephone, printer, photocopier 
or any machine having a human/machine interface. 

Example Application 

25 

One application for the above speech recognition system is in a telephony system. Figure 36 is a schematic diagram 
of a typical telephony system employed in an office environment. In particular, the system comprises a number of 
analogue or digital telephones 271 and modems 272 (which may be connected to computers), which are connected 
by telephone lines 293 to a local exchange 273 associated with that office Each telephone 271 is usually associated 

30 with a single user or a group of users, and is identified by the local exchange 273 by a caller ID. This allows users 
within the building to call other users by simply dialling the caller ID of the telephone associated with that other user 
The local exchange 273 is also connected, by a number of telephone lines 275, to the public exchange 277 so that 
remote users can contact users in the office and vice versa. Users who are directly connected to the local exchange 
273 and who can access the speech recognition user interface will be referred to hereinafter as local users. Other 

35 users will be referred to as remote users. The purpose of the local exchange 273 is to control the connections between 
internal telephones 271 and between calls to and from the public exchange 277. Additionally, the local exchange 273 
provides telephony services to the internal telephones 271 and controls the operation of services provided by the public 
exchange 277. 

Figure 37 is a schematic representation of one of the telephones 271 shown in Figure 36. In particular, telephone 

40 271 comprises a handset 281 which is connected to a telephone body 283 by line 285. The telephone body 283 has 
a liquid crystal display 287, a standard twelve-button keypad 289 and a number of function keys 291 . The telephone 
271 is connected to the local exchange 273 by the telephone line 293. In this embodiment, the local exchange 273 
can accept spoken commands for setting up calls between local users, for setting up calls between a local user and a 
remote user on the public exchange, and for accessing telephony services provided by the local exchange 273 and 

45 the public exchange 277. In order for the Ideal exchange 273 to be able to differentiate between voice commands and 
normal conversation between users, each handset 281 has a control button 295, which is used to delimit speech 
commands made by a local user from normal conversational speech. For example, if a local user of one of the tele- 
phones 271 wishes to call another local user within the office, then this may be achieved by the local user pressing 
the button 295 and speaking into the microphone in the handset 281 the word "call" together with either the caller ID 

50 of the user to be called or an identifier associated with that caller ID, such as the name of the user to be called. A signal 
from the button 295 together with the speech signal corresponding to the local user's utterance is then supplied to the 
local exchange 273, via the telephone line 293, where the speech command is recognised and the appropriate con- 
nections made. Further details of the speech recognition capability of the local exchange will be described below. 
Figure 38 is a schematic diagram showing in more detail, part of the structure of the local exchange 273. In par- 

55 ticular, the local exchange 273 has a switching network 301 and a control unit 303. A speech signal from a telephone 
271 is supplied on line 293a to the local exchange 273, and is either passed on to the switching network 301 or to the 
control unit 303, depending on the position of switch 305 which is controlled by the signal from button 295 (represented 
by arrow 306). In particular, if button 295 is not pressed down, then switch 305 will be connected to terminal A and the 
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speech signal from the local user will be supplied to the switching network 301 and out of the local exchange on line 
307b to its required destination. If on the other hand button 295 is pressed down, then switch 305 will be connected 
to terminal B, and the speech signal on line 293a, will be supplied to the control unit 303, which recognises the speech 
signal and outputs control signals 309 for controlling the operation of the local exchange 273. In this embodiment, the 
control unit 303 is connected by line 310 to the LCD display 287 of the telephone which was used to input the voice 
command. In this way, the control unit 303 is able to communicate with the user for the purposes of confirmation and 
the like. Alternatively, the control unit 303 could communicate with the user by outputting synthesised speech via a 
loudspeaker on the telephone 271 . In order to provide a full duplex communication path, a second communication path 
is provided through the local exchange 273 to the telephone 271. This second communication path is shown in Figure 
38 by line 293b and line 307a which are connected together via the switching network 301. 

A description of the control unit 303 will now be given in more detail with reference to Figure 39, which shows a 
block schematic diagram illustrating the principle elements of the control unit 303 shown in Figure 38. In particular, a 
speech signal from a telephone 271 is supplied to a recognition unit 321 which compares the speech signal with pre- 
stored models and outputs on line 323 a recognition result which is supplied to a command interpreter 325. The com- 
mand interpreter 325 identifies any commands and/or identifiers which are in the recognition result by comparing the 
recognition result with pre-stored dictionaries 328 and 330 stored in memory 327. In response, the command interpreter 
outputs on line 329 control signals which control the operation of a command executor 331 which controls user con- 
firmation, ensures that the user is not given misleading information and controls the appropriate telephony service(s). 
Each of these elements will now be described in more detail. 
20 The recognition unit 321 uses a speech recognition system similar to the one described above, and can therefore 

recognise continuously spoken utterances having a number of words. The recognition unit 321 has a number of pre- 
defined recognition results corresponding to the telephony services available. In this embodiment, recognition results 
are in English, although the system could be adapted for use with any language. To be able to access the telephony 
services, each local user must train the recognition unit 321 to associate specific input speech signals with correspond- 
ing recognition results. This training procedure produces a set of word, noise and language models for each local user. 
Therefore, since each local user has his own set of models, the actual speech command input by each local user does 
not have to be the same. For example, to access the automatic dialling telephony service, a first local user might train 
the speech recognition unit 321 to recognise the spoken command "ring" to access this service, whilst a second local 
user might train the recognition unit 321 to access the same service for the spoken command "call". 

When a new local user is added to the local exchange 273 an initial training routine, which is initiated by the local 
user pressing one of the function keys 291 on the telephone 271 , establishes word models for the speech commands 
that the new local user will input to access the most basic telephony services, i.e. automatic dialling, call transferring, 
call holding etc. The new local user is then able to use, to a limited extent, the speech recognition user interface of the 
local exchange 273. To be able to access the remaining telephony services via the speech recognition interface, the 
35 new local user must train the speech recognition unit 321 with the speech commands that he will use to access those 
services. This further training can be done incrementally and at the user's convenience. In this embodiment, the addi- 
tional training is initiated by the new local user pressing another one of the function keys 291 on the telephone 271. 
Upon initiation, the local exchange 273 prompts the new local user, via the LCD display 287, to press the key or 
combination of keys on the telephone 271 which would normally be pressed to access the telephony service that he 
wishes to generate word models and update the language model for. In response, the local exchange 273 prompts 
the new local user, via the LCD display 287, to input, one or more times via the handset 281 , a speech command which 
will be used to generate an appropriate word model which will be associated with that telephony service. After the word 
model has been generated, the language model is then updated to incorporate the new voice command. 

In operation, when a local user speaks into the handset 281 and presses the button 295 at the same time, the 
recognition unit 321 attempts to recognise the spoken utterance, and in this embodiment outputs a recognition result 
corresponding to the input utterance. However, at this stage the word or sequence of words output from the recognition 
unit 321 is meaningless to the telephony system. In order to give the recognition result some meaning, it is interpreted 
by the command interpreter 325. 

To give meaning to the recognition result the command interpreter 325 compares the recognition result with a 
language specific dictionary 328 and a telephone book 330 associated with the local user who inputs the speech 
command. Both the dictionary 328 and the telephone book 330 are stored in memory 327. The language specific 
dictionary 328 is pre-set and depends on the telephony services which can be provided by the local exchange 273 and 
on the language of the words output by the speech recognition unit 321 . The dictionary associates some of the words 
output by the recognition unit 321 , with a corresponding telephony service. The user-defined telephone book 330 stores 
the telephone numbers and identifiers of other local users connected to the local exchange 273 and of remote users 
connected to the public exchange 277. 

In this embodiment, each local user connected to the local exchange 273 has an associated telephone book 330, 
and when the local user is identified, either by the telephone 271 that he uses or by some other identification procedure. 
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the corresponding word, noise and language models are loaded into the recognition unit 321 and the corresponding 
telephone book 330 is loaded into memory 327. The telephone book 330 operates in a similar manner to the pre-stored 
dictionary 328, except it can be modified by the user, tor example to add new entries, or to change telephone numbers 
associated with existing entries. It a new entry is to be added to a user's telephone book 330, then he must train the 

s speech recognition unit 321 to be able to recognise the spoken utterance he will input to identify the other user. 

In this embodiment, a local user can add a new entry into his telephone book 330 in the following manner. Firstly, 
the local user indicates to the local exchange 273 that he wishes to add a new entry to his telephone book 330 by 
inputting the spoken command "new entry" via the speech recognition user interface. In response, the local exchange 
273 prompts the user, via the display 287, to input in textual form the identifier of that user via the keypad 289. Once 

io the local user has typed in an appropriate identifier, the local exchange 273 then prompts the user, via the LCD display 
287, to input the telephone number of the user to be added to the telephone book 330. Once the local user has input 
the appropriate number using the keypad 289, the local exchange 273 then creates an appropriate entry in the tele- 
phone book 330. Finally, the local exchange 273 then prompts the user, via the display 287, to input in spoken form 
one or more times, the utterance he will input to identify that user, so that the recognition unit 321 can create an 

is appropriate word model and adapt the language model. 

The command interpreter 325, therefore receives and interprets the recognition result output by the speech rec- 
ognition unit 321 to identify which telephony service is required and/or the identifier and telephone number of another 
user. The command executor 331 receives the output from the command interpreter 325 and initiates a system check, 
to ensure that the requested telephony service does not contradict what is already happening in the system. If the 

20 requested telephony service makes sense, then the command executor 331 requests the local user, via the LCD display 
287, to confirm that what the command executor 331 is about to do is what the local user wants. If confirmation is 
received, then the command executor executes the appropriate telephony service. 

For example, if the local user inputs the speech command "call Tom" then, after recognition and interpretation, the 
command executor 331 outputs on the LCD display 287 "do you want to call Tom?" and waits for a confirmation signal. 

25 Once a confirmation signal is received, for example in response to the input of the speech command "yes", the command 
executor causes the local exchange 273 to take the appropriate actions. Similarly, if the command executor 331 de- 
termines that the requested telephony service identified by the command interpreter contradicts what is already hap- 
pening in the system, then it informs the local user why his input speech command does not make sense. For example, 
in the above situation, where the input speech command is "call Tom" but the status check tells the command executor 

so 331 that the user is already talking to Tom, then the command executor will output on the display "you are already 
speaking to Tom". 

In this embodiment, the local exchange 273 stores, among other things, the following status information 332 for 
each local user, i.e. for each telephone 271 connected to the local exchange 273, for use by the command executor 331 . 

35 who the user is currently speaking to 

who the user is dialling 

who the user has on hold 

whether or not the user is playing messages 

who has that user on hold (if known) 
40 who has that user in a conference call (if known) 

By storing this information, the command executor 331 can identify whether or not the requested telephony service 
identified by the command interpreter 325 makes sense. 

In addition to the above status information 332, the command executor 331 also stores, in an "action pending" 

45 variable, the last output received trom the command interpreter 325. The output stored in the action pending variable 
remains there until either a confirmation signal is input by the local user or until it is replaced by a new output corre- 
sponding to a new speech command input by the local user. 

Not only does the status information 332 provide a convenient way for the command executor 331 to be able to 
check whether or not a speech command makes sense, it can also be relied upon by the command executor 331 , 

so when the recognition result comprises only an identifier. For example, if the command interpreter 325 identifies from 
the recognition result that the local user has only input the identifier "Tom", then it outputs a general command together 
with the identifier Tom and his associated telephone number to the command executor 331. The general command 
causes the command executor 331 to check the status information 332 to see what command would make sense. In 
the above example, the general command causes the command executor 331 to check to see whether or not the user 

55 Tom is on hold, if not, then it checks to see if the local user is currently speaking to Tom. Again if not, then the command 
executor 33 outputs "do you want to call Tom" on the LCD display 287 and places the command "call Tom 1 " in the action 
pending variable. 

If on the other hand the identifier is "line 1 " (indicating an incoming external call from someone not known to the 
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system), which does not have an associated caller ID, then the command interpreter 325 outputs the identifier B line 1 " 
to the command executor with a limited functionality command which tells the command executor 331 that the command 
cannot be "call line 1 " as this does not make sense. 

In addition tooutputting confirmation requests, the command executor also outputs to the LCD display 287 status 
information of calls currently in progress between users, especially when the status changes. For example, if Tom is 
speaking to the user David, and Tom requests to put David on hold, then, after command confirmation etc. , the command 
executor 331 puts David on hold, outputs on Tom's display "David is on hold" and outputs on David's display, if David 
is a local user, "Tom has put you on hold". However, confusion can arise if events occur which cause the status of the 
local exchange 273 to change quickly. For example, if David rings off during the confirmatory stage for the command 
"put David on hold", then the command executor would output "David has rung off", and then if Tom confirms his 
command to put David on hold, the command executor 331 would then output "David is on hold'', when in fact he has 
rung off . In order to avoid the problems of such conflicting messages, while the system enters the confirmation process 
the status information of the system is held or frozen and any new status information is buffered. Additionally, in order 
to give the users time to read a message output from the command executor 331 , each message is displayed for a 
'5 set minimum amount of time. 

As mentioned above, modern telephony systems can store messages for each user in an associated mailbox if 
he is unable to take a call. In this embodiment, the local exchange 273 lists the messages from callers in each mailbox 
in three notional lists. One for listing new messages, one for listing old messages that have been played back to the 
user and one for listing a current selection of messages to be played. Additionally, each mailbox has a so called waste 
basket in which messages are temporarily stored before deletion. In practice, the messages are listed in a single list, 
and each message has a number of identifiers which tell the local exchange 273 which list(s) each message belongs 
to. Figure 40 is a schematic diagram illustrating the new message list 351 , the old message list 353, the current message 
list 355 and the waste basket 357 described above. 

In addition to storing the spoken message, the local exchange 273 also stores the time and date that the message 
was left, and the caller ID of the caller that leaves the message. The caller ID may be an internal telephone number 
or the telephone number of a telephone connected to the public exchange. Therefore, in this embodiment, if a local 
user is interested to find out whether or not a particular caller (who is in the telephone book 330 associated with that 
local user) has left any messages, then he can ask the system to play back messages from that caller. It would also 
be possible to modify this embodiment, so that local users can use this message retrieval system to replay messages 
30 from callers not in the telephone book 330. However, in such an embodiment, the speech recognition unit would have 
to be able to recognise continuously spoken digits input in any order, which would be difficult to implement using the 
speech recognition system above, because of the requirements of the language model. Therefore, in such a system, 
two parallel speech recognition units might be used, one for recognising normal speech commands, and one for rec- 
ognising digits. 

35 Figure 41 is a flow chart which illustrates the processing steps which occur when a local user asks the local ex- 

change 273 to replay new messages from a particular caller. In step s301 the local exchange 273 compares the caller 
ID of the particular caller with the caller IDs associated with the messages stored in the new message list 351 . If the 
local exchange determines, in step s302, that there is no match, then the local exchange 273 outputs on the local 
user's display 287, in step s303, that there are no messages from that particular caller and the processing ends. If on 
40 the other hand the local exchange 273 determines, in step s302, that there is a match, then in step s304 the local 
exchange 273 lists the appropriate messages in the current message list 355, and requests the user to confirm the 
speech command. If confirmation is not received, or if another speech command is input, then the processing ends. If 
confirmation is received, then the processing proceeds to step s306, where the local exchange 273 plays the first 
message on the current message list. Additionally, as indicated by arrow 352 shown in fig 39, once a message has 
^ been played from the current message list, it is moved from the new message list 351 to the old message- list 353. 

After the first message has been played, the local exchange 273 then determines, in step s307, whether or not all 
the messages in the current list 355 have been played. If all the messages in the current list 355 have not been played, 
then the local exchange 273 wails, in step s309, for the local user to input the next speech command. If the next speech 
command input by the local user is to play the next message, then the local exchange 273 plays the next message on 
the current message list 355, and the processing returns to step s307. If the local user does not request the next 
message to be played but instead requests the last message to be replayed, then the local exchange 273 replays the 
last message played and returns to step s309. 

When the local user is playing back messages, he is not restricted to speech commands associated with the 
mailbox facility. For example, if after the first message has been played, the local user might wish to call another user 
to relay the message, rather than hear the next message. After doing this, the local user can then ask for the next 
message to be played. To achieve this, a pointer is used which points to the last message on the current message list 
355 which was played. 

Once all the messages on the current message list 355 have been played, the local exchange 273 informs the 
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local user of this via the display 287. The current message list 355 is not initialised until the telephone handset 281 is 
replaced on the telephone body 283 or until it is overwritten by another selection of messages to be played. In a similar 
manner to the replaying of new messages, old messages can also be selected for replay. Once messages have been 
played or once they no longer need to be kept, the local user can input an appropriate speech command to delete the 

s messages. For example, once a local user has replayed all new messages from the user David, he may input the 
speech command "Delete old messages from David". After confirmation the local exchange places all old messages 
from David into the waste basket 357. 

As described above, the local user can ask the local exchange 273 to repeat an action. In order to be able to do 
this, the local exchange 273 stores, in a stored variable the last repeatable action. Therefore, when the local user 

to inputs the speech command "repeat", the local exchange 273 executes the action which is stored in that variable. In 
addition, in order to facilitate repeating commands, the system uses a general pointer which tells the local exchange 
which facility the user is currently using, eg the mailbox facility or the telephone call facility. This pointer is also used 
to save time in determining what is required when a vague command is input. For example, if the user inputs the 
command "stop", i.e. to stop playing a message or to stop dialling someone, then by using this general pointer to 

is identify what facility the user is currently using, the local exchange 273 does not have to identify all actions that are 
currently in progress in each facility. 

As mentioned above, the telephony system of this embodiment can set up and control conference calls between 
a number of users. In this embodiment, a conference call is initiated in the following manner. Firstly, a local user calls 
another user, for example, Tom and then puts him on hold. The local user then calls another user who is to be included 

20 jn the conference, for example David, and then while speaking to David presses the button 295 on the handset 281 
and inputs the speech command "include" together with the identifer for Tom. The local exchange 273 then outputs on 
the local user's display 287 the query "do you want to include Tom?", and after confirmation by the local user, the local 
exchange 273 makes the appropriate connection via the switching unit 301 so that the local user is connected to both 
Tom and David. 

2S in this way, the local user can call Tom and inform him that he wishes to arrange a conference together with David 

and then, whilst Tom is on hold, the local user can then call David and inform him that Tom is on another line and 
holding, and that he wishes to talk to both Tom and David together. In this way, both Tom and David will know that they 
are about to be included in a conference call, and they will know who will be in the conference. Other users may also 
be included in the conference in a similar manner. 

30 In this embodiment, for convenience, only the local user who initiates the first call is in control of the conference, 

and can disconnect people from the conference, place some of the people in the conference on hold and include further 
people in the conference. However, it is envisaged that this embodiment could be modified to allow any of the callers 
in the conference to be able to control to some extent the conference, even callers from the public exchange 277, 
Callers from the public exchange 277 can only control the conference if they can send an appropriate control signal, 

35 for example a tone signal produced by a key on the user's handset, together with the speech commands down the 
telephone line 275 to the local exchange 273, so that the speech commands are fed into the control unit 303 and not 
the switching unit 301 . 

Although in the above described telephony system, a single control unit 303 was used, it would be possible to use 
several of these control units in parallel, thereby allowing more than one user to be able to input speech commands 

40 at the same time. Alternatively, the use of the control unit 303 could be time multiplexed, thereby allowing a number 
of different users to be able to use the control unit 303 at the same time. In another embodiment, each telephone 271 
could have a control unit 303 for processing speech commands. However, this embodiment suffers from the disadvan- 
tage that the cost of each telephone increases dramatically, due to the need for specialised software and hardware to 
be built into each telephone 271 . 

45 By using a speech recognition system which stores word models and uses a language model to define allowed 

sequences of input words, the speech recognition interface can accept, in a single utterance, both a request for a 
telephony service and an identifier of another user, thereby alleviating the need for repetitive iteration between the user 
and the interface. 

Additionally, although the telephony system of this embodiment uses the speech recognition system described 
50 with reference to Figures 1 to 35, other speech recognition systems could be used in the telephony system. However, 
by using the speech recognition system described with reference to Figures 1 to 35, it is possible to provide the te- 
lephony system to end users, with no pre-stored models. Further, since the system breaks down the input commands 
into individual words, the storage space required to store the reference models may be significantly reduced if there 
is a large amount of duplication of the words making up the speech commands. 
55 The present invention is not intended to be limited by the exemplary embodiments described above, and various 

other modifications and embodiments will be apparent to those skilled in the art. 
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Claims 



1. A method of performing a dynamic programming pattern matching process between a sequence of input patterns 
representative of an input signal, and a number of stored sequences of reference patterns, each sequence being 
representative of a reference signal, wherein the method processes each input pattern in turn with respect to at 
least some of the reference signals in turn, by: 

(1) defining as active patterns the reference patterns of a current reference signal which are at the end of a 
dynamic programming path for a current input pattern being processed, each path representing a possible 
matching between an ordered sequence of reference patterns and an ordered sequence of input patterns 
ending at said current input pattern, and listing the active patterns for the current input pattern in a current 
active list; 

(2) for each active pattern, storing in a store associated with that active pattern, a cumulative value represent- 
ative of the score for the dynamic programming path which ends at that active pattern for said current input 
pattern; and 

(3) updating said cumulative values and propagating said dynamic programming paths based on constraints 
which are placed on the dynamic programming path propagation, by processing each active pattern of said 
current reference signal in reverse sequential order by: 

(A) updating the cumulative value stored in the store associated with a current active pattern being proc- 
essed, using said current input pattern; and then 

(B) propagating the dynamic programming path associated with the current active pattern, and listing, if 
it is not already listed, each reference pattern of the current reference signal, which may be at the end of 
that dynamic programming path for the succeeding input pattern, in anew active list; and 

wherein the propagation of each dynamic programming path for a current reference signal is controlled using 
a pointer associated with the current reference signal, which identifies the reference pattern which is the earliest 
in the sequence of patterns of the current reference signal listed in the new active list, after the processing of the 
preceding active pattern, such that the propagation of each dynamic programming path is achieved without the 
need to search the new active list to identify which reference patterns, of the current reference signal, have been 
listed on the new active list as a result of processing preceding active patterns. 

2. A method according to claim 1 , wherein the following steps are performed in step 3(B): 

(i) determining which of the reference patterns of the current reference signal are potentially at an end of the 
dynamic programming path which ends at said current active pattern for said succeeding input pattern, based 
upon said constraints which are placed on the dynamic programming path propagation; and then 

(ii) propagating the dynamic programming path, updating the new active list and copying appropriate cumu- 
lative values into stores associated with the reference patterns determined in step (i), by processing each 
reference pattern determined in step (i). 

3. A method according to claim 2, wherein each reference pattern determined in step (i) of claim 2, except the current 
active pattern if it is one of those reference patterns, is processed by: 

(a) determining whether a current reference pattern being processed is sequentially beyond any reference 
pattern identified by said pointer; then 

(b) if the current reference pattern is the same as or sequentially beyond the identified reference pattern, then 
copying the cumulative value stored in the store associated with said current active pattern into the store 
associated with the current reference pattern, if it is better than the cumulative value already stored there; and 

(c) if the current reference pattern is sequentially before the identified reference pattern or if there are no 
reference patterns of the current reference signal in the new active list, then copying the cumulative value 
stored in the store associated with said current active pattern into the store associated with said current ref- 
erence pattern, and listing said current reference pattern in the new active list. 

4. A method according to claim 2 or 3, wherein if one of the reference patterns determined in step (i) of claim 2 is the 
current active pattern, then the processing of the current active pattern in step (ii) of claim 2 comprises the step 
of listing the current active pattern in the new active list, if this is not contrary to any constraint placed on the 
dynamic programming process. 
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5. A method according to any preceding claim, wherein after the new active list has been updated by the processing 
of the current active pattern, said pointer associated with the current reference signal is set to identify the reference 
pattern on the new active list which is the earliest in the sequence of patterns of the current reference signal. 

6. A method according to any preceding claim, wherein the processing of the current input pattern is performed before 
the succeeding input pattern is received. 

7. A method according to any of claims 1 to 5, wherein the whole input signal is received before the first input pattern 
is processed. 

8. A method according to any preceding claim, wherein each reference signal has associated therewith a current 
active list and new active list. 

9. A method according to any preceding claim, wherein when a reference pattern is added to said new active list it 
is placed at the end thereof. 

10. A method according to any of claims 2 to 9, wherein the reference patterns processed in step (ii) of claim 2, are 
processed in reverse sequential order. 

20 11. A method according to any preceding claim, wherein the method only performs step (3) of claim 1 for the current 
active pattern, if the cumulative value associated therewith is better than a threshold value. 

12. A method according to claim 11, wherein said threshold value is varied to try to maintain the number of active 
patterns processed for each input pattern to be below a given maximum number. 

25 

13. A method according to claim 12, wherein the threshold value used during the processing of the succeeding input 
pattern is determined during the processing of the current input pattern, and is dependent upon the total number 
of reference patterns in the new active list or lists for the succeeding input pattern. 

30 14. A method according to any preceding claim, wherein one of said dynamic programming constraints is that a limit 
is placed on the number of consecutive input patterns that a reference pattern can be matched with, on the same 
dynamic programming path. 

15. A method according to any preceding claim, wherein one of said dynamic programming constraints is that if a 
35 reference pattern is matched with an input pattern, then a limited number of reference patterns which are sequen- 
tially beyond that reference pattern can be matched with the succeeding input pattern, on the same dynamic 
programming path. 

16. A method according to any preceding claim, wherein one of said dynamic programming constraints is that if a 
reference pattern is matched with an input pattern, then reference patterns which are sequentially before that 
reference pattern can not be matched with the succeeding input pattern, on the same dynamic programming path. 

17. A method according to any preceding claim, wherein said reference patterns are representative of a template, and 
wherein said cumulative values are distance measures. 

45 

18. A method according to any of claims 1 to 16, wherein said reference patterns are representative of a statistical 
model, and wherein said cumulative values are probabilistic measures. 

19. A method according to any preceding claim, wherein said input signal can be matched with a sequence of said 
50 reference signals, by allowing dynamic programming paths propagating in one reference signal to subsequently 

propagate into other reference signals. 

20. A method according to claim 1 9, wherein only the dynamic programming path which has the best cumulative value 
of all the dynamic programming paths which leaves the reference pattern for the current input pattern, propagates 

55 further. 

21. A method according to claim 19 or 20, wherein the sequence of reference signals, against which the input signal 
can be matched, is constrained by a set of defined rules. 
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22. A method according to any of claims 19 to 21, wherein after the current input pattern has been processed with 
respect to the reference signals, the method processes those reference signals to update the new active list and 
to update the cumulative values associated with the reference patterns at the beginning of those reference signals, 
which are potentially at an end of a dynamic programming path which enters the corresponding reference signal! 

5 based upon said constraints, using the best cumulative value of all the dynamic programming paths which can 

enter that reference signal. 

23. A method according to any preceding claim, wherein said input signal is representative of a speech signal, and 
wherein each input pattern comprises a number of parameters representative of the acoustic properties of the 

10 speech signal during a corresponding time frame. 

24. A method according to claim 23, wherein said input speech signal can be matched to a sequence of reference 
speech signals, and wherein the allowed sequences are defined by a language model. 



« 25. 



A method according to claim 24, wherein the end of a dynamic programming path which leaves a reference signal 
when processing the current input pattern can be matched with a pattern representative of background noise for 
succeeding input patterns. 
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26. A speech recognition method for recognising an input speech signal by comparing it with a plurality of reference 
speech signals, the method comprising the steps of: 

extracting a sequence of input patterns representative of said input speech signal; 

storing sequences of reference patterns, each sequence being representative of a corresponding reference 
speech signal; 

matching the sequence of input patterns with the reference speech signals, using a method according to any 
of claims 23 to 25; and 

providing a recognition result Irom cumulative values determined by said matching step. 

27. A method according to claim 26, wherein said recognition result is provided by determining which of the dynamic 
programming paths which end at the last input pattern in the sequence has the best cumulative value. 

28. A method for adapting existing reference models which are used in a pattern matching system, wherein each 
reference model comprises a sequence of reference patterns, the method comprising the steps of: 

(a) inputting a number of input signals for which the content is known; 

(b) processing each input signal to generate a sequence of representative input patterns; 

(c) for each input signal, aligning the representative sequence of input patterns with the sequence or sequences 
of reference patterns of the existing reference model or models of the signals known to be in that input signal; 

(d) for each reference pattern which is aligned with a number of input patterns of one or more input signals: 

(i) combining the input patterns of the aligned input signals; and 

(ii) replacing that reference pattern of the reference model with the combined input pattern determined in 
step (i). 

29. A method according to claim 28, wherein the aligned input patterns are combined by averaging them. 

30. A method according to claim 28 or 29, wherein said reference models represent speech, and wherein said input 
signals are speech signals for which the speech content is known. 

31. A method according to claim 30, wherein each reference model is representative ol one or more words. 

32. A method according to any of claims 28 to 31 , wherein for each reference pattern of a reference model aligned 
with at least one input signal for which there are no aligned input patterns of the input signals, that reference pattern 
is replaced with a pattern derived by interpolating between or extrapolating from neighbouring reference patterns 
of that reference model which have already been replaced. 

33. A method according to claim 32, wherein said reference pattern is replaced by interpolating between or extrapo- 
lating from the nearest neighbouring reference patterns. 
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34. A data carrier programmed with software for carrying out a method according to any one of claims 1 to 33. 

35. An apparatus for carrying out a method according to any of claims 1 to 33. 

5 36. A control system for controlling a telephony system, comprising: 

a speech recognition user interface for allowing a user to input speech commands for controlling the telephony 
system, and for outputting a recognition result based on comparing the input speech commands with pre- 
stored reference models; 

10 control means, responsive to the recognition result output from the interface, for controlling the telephony 

system in accordance with an input speech command; 

characterised in that the speech recognition user interface is adapted to be able to recognise continuously 
spoken commands comprising a plurality of words defining a desired telephony service and an identifier of another 
15 user by comparing allowed sequences of word models, defined by a stored language model, with the input speech 

command, and in that the control means comprises execution means for executing an operation corresponding to 
the input speech command. 

37. A telephony system comprising: 

20 

a speech recognition user interface for allowing a user to input speech commands for controlling telephony 
services provided by the system, and for outputting a recognition result based on comparing the input speech 
commands with pre-stored reference models; and 

execution means, responsive to the recognition result output from the interface, for executing an operation 
2S corresponding to the speech command; 

wherein each user of the system is identified by a telephone number and an associated identifier, and wherein 
the execution means is adapted to predict, using current system status information, what telephony service 
is wanted, if the user inputs, via the speech recognition user interface, only the identifier of another user. 

30 38. A system according to claim 36 or 37, wherein the execution means is adapted to communicate with users of the 
system in dependence upon information representative of the current status of the system, wherein the execution 
means is adapted 

i) to hold the current system status information; 
35 ii) to check that the operation corresponding to the speech command does not conflict with the current system 

status information; and 

iii) if there is no conflict, to request the user to confirm the speech command prior to execution, and 

wherein a buffer is provided for buffering new system status information which is generated whilst the exe- 
40 cution means awaits user confirmation. 

39. A system according to claim 37 or 38, wherein the status information comprises, for each user, a selection from: 
who the user is currently speaking to, who the user is dialling, who is on hold, who is trying to ring that user, whether 
that user is playing messages, who has that user on hold and who has that user in a conference. 

45 

40. A system according to any one of claims 36 to 39, wherein the telephony services comprises a selection from: 
setting up a call, transferring a call, holding a call, returning to a call, setting up a conference call and message 
selection and replaying. 

so 41. a system according to any one of claims 36 to 40, wherein the control means further comprises interpretation 
means for interpreting the recognition result, which uses a factory set pre-stored dictionary. 

42. A system according to any one of claims 36 to 41, wherein each user in the system has an associated storage 
means for storing the telephone numbers and associated identifiers of other users, whereby a user can designate 

55 another user of the system by speaking the corresponding identifier into the speech recognition user interface. 

43. A system according to claim 42 when not dependent upon claim 37, wherein the execution means is adapted to 
predict, using current system status information, what telephony service is wanted if the user inputs, via the speech 
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recognition user interface, only the identifier of another user. 



44. A system according to any one of claims 36 to 43, wherein the speech recognition user interface can be trained 
to recognise new speech commands. 

5 

45. A system according to claim 44, wherein means is provided for adapting the language model to accommodate the 
new speech commands, and wherein means is provided for generating new reference models for those words in 
the new speech commands for which there is not an existing reference model. 

10 46. A system according to any one of claims 36 to 45, wherein each user has an associated set of reference models. 

47. A system according to any one of claims 36 to 46 provided in a local exchange. 

48. A telephony system comprising a control system according to any one of claims 36 to 47 for controlling the telephony 
*5 system and a number of communication devices for use by users of the telephony system, which are interconnected 

via a local exchange. 

49. A system according to claim 48, wherein the execution means is adapted to communicate with each of the users 
via the respective communication devices, information representative of the current status of the system 

20 

50. A system according to claim 48 or 49, wherein at least some of the communication devices have an associated 
display arranged to display messages representative of the operation corresponding to the input speech command, 
for a predetermined amount of time. 

2S 51. A system according to any of claims 48 to 50, wherein the local exchange is connected to the public exchange so 
that users connected to the local exchange can communicate with remote users on the public exchange and vice 
versa. 



52. A system according to any of claims 48 to 51 , further comprising a mail box facility which stores messages for 
users of the system left by callers, when the users are unable to take the calls. 

53. A system according to claim 52, wherein each message stored in the mail box facility is associated with the tele- 
phone number of the caller who left the message. 



35 54. A system according to claim 53, wherein users can request, via the speech recognition user interface, the mail 
box to replay messages from a particular caller. 

55. A system according to claim 54, wherein after replaying one of a plurality of selected messages a user can access 
other telephony services and return and replay the remaining selected messages after using those other telephony 

40 services. 

56. A system according to any of claims 48 to 55, wherein the use of the speech recognition user interface and the 
execution means is time multiplexed between a number of different users. 



45 



so 



ss 



57. A system according to any of claims 48 to 56, wherein a plurality of speech recognition user interfaces and execution 
means are provided, for simultaneous use by a plurality of different users. 

58. A system according to any of claims 36 to 44, provided in a communication device. 

59. A system according to any one of claims 36 to 58 in which said speech recognition user interface is arranged to 
recognise an input speech command using a speech recognition method according to claim 26. 

60. A method of controlling a telephony system comprising the steps of: 

providing a system according to any preceding claim; 

inputting a speech command into the system via the speech recognition user interface; 

outputting a recognition result based on a comparison of the input speech command with pre-stored reference 

models made by the speech recognition user interface; and 
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controlling the telephony system in response to the recognition result. 

61 . A data carrier programmed with software for carrying out a method according to claim 60. 

62. A mail box facility for use with a telephony system, comprising: 

a speech recognition user interface for allowing a user to input speech commands for controlling the mail box 
facility, and for outputting a recognition result based on comparing the input speech commands with pre-stored 
reference models; 

control means, responsive to the recognition result output from the interface, for controlling the mail box facility 
in accordance with an input speech command; and 

storage means for storing messages left by callers, when the users are unable to take the calls; 



characterised in that each message stored in the mailbox is associated with the telephone number of the 
caller who left the message, whereby users can request, via the speech recognition user interface, the mailbox 
facility to replay messages from a particular caller. 
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